yii1的笔记

$sql = 'SELECT * FROM to8to_worker_item limit 10';
$res = Yii::app()->db->createCommand($sql)->queryAll();

这是yii1中写sql语句来查询数据库的写法,queryRow()方法只查一条,查询结果是数组,无需toArray()也不能够调用这个方法;




$cri = new CDbCriteria();
$cri->addCondition('id = 1','AND');//where id = 1 第二个参数默认省略,若是是OR关系时就起做用了
$cri->addInCondition('id',array(1,2,3));//where id in (1 ,2, 3)
$cri->addNotInCondition('id',array(1,2,3));//where id not in (1 ,2 ,3)
$cri->addSearchCondition('name','zhang');//模糊搜索 where name like '%zhang%'
$cri->addBetweenCondition('id',1,5);//where id between 1 and 5mysql

$cri->compare('id',1);//where id = 1
$cri->compare('id',array(1,2));//where id in (1,2)sql

$cri->addCondition('id = :id');//占位符的使用方法
$cri->params[':id']=1;数据库

$cri->select= 'id,name,age';//查询字段 select id name age,不重写默认是 select *
$cri->jion = 'left jion books on books.id = students.id ';//链表查询
$cri->distinct = FALSE; //是否惟一查询,默认false数组

student::model()->findAll($cri);app

这是yii1中用CDbCriteria对象来收集查询条件的写法,查询结果是对象yii


$rows = (new \yii\db\Query())
->select(['id','name'])
->from('students')
->where(['age'=>10])
->limit(10)
->all();ui

$rows = Yii::app()->db->createCommand()
->select(['id','name'])
->from('students')
->where(['age'=>10])
->limit(10)
->all();对象

query builder和Command现都支持链式调用排序


mysql要先排序在限制条数,一边状况下limit是最后加上去事务


new CDbCriteria()->compare($column,$value,$partialMatch=false,$operator='AND');
//search时$column匹配$value,false为彻底匹配,true为模糊匹配,$operator为操做符

事务的操做$shiwu = Yii::app()->db->beginTransaction();try { $update['coupons_enddate'] = 0; $update['coupons_money'] = 0; $res = Yii::app()->db->createCommand()->update('{{owner}}', $update, "coupons_money>0 and coupons_enddate <$timestamp"); $a = Yii::app()->db->createCommand($sql)->execute(); if($a && $res) { $shiwu->commit(); echo "<script>alert('成功清除现金券过时用户数据{$num}条')</script>"; Yii::app()->end(); }else { throw new Exception('修改不成功'); }} catch (Exception $exc) { echo "<script>alert('没找到须要清除的数据或清除失败')</script>"; $shiwu->rollback(); Yii::app()->end();}

相关文章
相关标签/搜索