Yii2――使用数据库操作汇总(增删查改、事务)


Posted in PHP onDecember 19, 2016

本文介绍了 Yii2——使用数据库操作汇总(增删查改、事务),具体如下:

对象操作

查询

//1.简单查询 
$admin=Admin::model()->findAll($condition,$params); 
$admin=Admin::model()->findAll("username=:name",array(":name"=>$username)); 
  
$infoArr= NewsList::model()->findAll("status = '1' ORDER BY id DESC limit 10 "); 
  
//2. findAllByPk(该方法是根据主键查询一个集合,可以使用多个主键) 
$admin=Admin::model()->findAllByPk($postIDs,$condition,$params); 
$admin=Admin::model()->findAllByPk($id,"name like :name and age=:age",array(':name'=>$name,'age'=>$age)); 
$admin=Admin::model()->findAllByPk(array(1,2)); 
  
//3.findAllByAttributes (该方法是根据条件查询一个集合,可以是多个条件,把条件放到数组里面) 
$admin=Admin::model()->findAllByAttributes($attributes,$condition,$params); 
$admin=Admin::model()->findAllByAttributes(array('username'=>'admin')); 
  
//4.findAllBySql (该方法是根据SQL语句查询一个数组) 
$admin=Admin::model()->findAllBySql($sql,$params); 
$admin=Admin::model()->findAllBySql("select * from admin where username like :name",array(':name'=>'%ad%')); 
User::find()->all();  此方法返回所有数据; 
User::findOne($id);  此方法返回 主键 id=1 的一条数据(举个例子);  
User::find()->where(['name' => '小伙儿'])->one();  此方法返回 ['name' => '小伙儿'] 的一条数据; 
User::find()->where(['name' => '小伙儿'])->all();  此方法返回 ['name' => '小伙儿'] 的所有数据; 
User::find()->orderBy('id DESC')->all();  此方法是排序查询; 
User::findBySql('SELECT * FROM user')->all(); 此方法是用 sql 语句查询 user 表里面的所有数据; 
User::findBySql('SELECT * FROM user')->one(); 此方法是用 sql 语句查询 user 表里面的一条数据; 
User::find()->andWhere(['sex' => '男', 'age' => '24'])->count('id');  统计符合条件的总条数; 
User::find()->one();  此方法返回一条数据; 
User::find()->all();  此方法返回所有数据; 
User::find()->count();  此方法返回记录的数量; 
User::find()->average();  此方法返回指定列的平均值; 
User::find()->min();  此方法返回指定列的最小值 ; 
User::find()->max();  此方法返回指定列的最大值 ; 
User::find()->scalar();  此方法返回值的第一行第一列的查询结果; 
User::find()->column();  此方法返回查询结果中的第一列的值; 
User::find()->exists();  此方法返回一个值指示是否包含查询结果的数据行; 
User::find()->batch(10); 每次取 10 条数据  
User::find()->each(10); 每次取 10 条数据, 迭代查询 
二、查询对象的方法 
//根据主键查询出一个对象,如:findByPk(1); 
$admin=Admin::model()->findByPk($postID,$condition,$params); 
$admin=Admin::model()->findByPk(1); 
  
//根据一个条件查询出一组数据,可能是多个,但是他只返回第一行数据 
$row=Admin::model()->find($condition,$params); 
$row=Admin::model()->find('username=:name',array(':name'=>'admin')); 
  
//该方法是根据条件查询一组数据,可以是多个条件,把条件放到数组里面,查询的也是第一条数据 
$admin=Admin::model()->findByAttributes($attributes,$condition,$params); 
$admin=Admin::model()->findByAttributes(array('username'=>'admin')); 
  
//该方法是根据SQL语句查询一组数据,他查询的也是第一条数据 
$admin=Admin::model()->findBySql($sql,$params); 
$admin=Admin::model()->findBySql("select * from admin where username=:name",array(':name'=>'admin')); 
  
//拼一个获得SQL的方法,在根据find查询出一个对象  
$criteria=newCDbCriteria;  
$criteria->select='username';// only select the 'title' column  
$criteria->condition='username=:username';  //请注意,这是一个查询的条件,且只有一个查询条件.多条件用addCondition 
$criteria->params=array(":username=>'admin'"); 
$criteria->order ="id DESC"; 
$criteria->limit ="3"; 
$post=Post::model()->find($criteria);// $params isnot needed  
  
//多条件查询的语句 
$criteria= new CDbCriteria;    
$criteria->addCondition("id=1");//查询条件,即where id = 1  
$criteria->addInCondition('id',array(1,2,3,4,5));//代表where id IN (1,2,3,4,5,);  
$criteria->addNotInCondition('id',array(1,2,3,4,5));//与上面正好相法,是NOT IN  
$criteria->addCondition('id=1','OR');//这是OR条件,多个条件的时候,该条件是OR而非AND  
$criteria->addSearchCondition('name','分类');//搜索条件,其实代表了。。where name like '%分类%'  
$criteria->addBetweenCondition('id', 1, 4);//between 1 and 4 
$criteria->compare('id', 1);  //这个方法比较特殊,他会根据你的参数自动处理成addCondition或者addInCondition. 
$criteria->compare('id',array(1,2,3));  //即如果第二个参数是数组就会调用addInCondition  
  
  
$criteria->select ='id,parentid,name';//代表了要查询的字段,默认select='*';  
$criteria->join ='xxx'; //连接表  
$criteria->with ='xxx'; //调用relations  
$criteria->limit = 10;  //取1条数据,如果小于0,则不作处理  
$criteria->offset = 1; //两条合并起来,则表示 limit 10 offset 1,或者代表了。limit 1,10  
$criteria->order ='xxx DESC,XXX ASC' ;//排序条件  
$criteria->group ='group 条件';  
$criteria->having ='having 条件 ';  
$criteria->distinct = FALSE;//是否唯一查询 
三、查询个数,判断查询是否有结果 
//该方法是根据一个条件查询一个集合有多少条记录,返回一个int型数字 
$n=Post::model()->count($condition,$params); 
$n=Post::model()->count("username=:name",array(":name"=>$username)); 
  
//该方法是根据SQL语句查询一个集合有多少条记录,返回一个int型数字 
$n=Post::model()->countBySql($sql,$params); 
$n=Post::model()->countBySql("select * from admin where username=:name",array(':name'=>'admin')); 
  
//该方法是根据一个条件查询查询得到的数组有没有数据,如果有数据返回一个true,否则没有找到 
$exists=Post::model()->exists($condition,$params); 
$exists=Post::model()->exists("name=:name",array(":name"=>$username)); 
四、新增 
$admin= new Admin;     
$admin->username =$username; 
$admin->password =$password; 
if($admin->save() > 0){echo "添加成功"; }else{echo "添加失败"; } 
五、修改 
Post::model()->updateAll($attributes,$condition,$params); 
$count=Admin::model()->updateAll(array('username'=>'11111','password'=>'11111'),'password=:pass',array(':pass'=>'1111a1')); 
if($count> 0){ echo "修改成功"; }else{echo "修改失败"; } 
  
$rt= PostList::model()->updateAll(array('status'=>'1'),'staff_id=:staff AND host_id=:host',array(':staff'=>$staff_id,':host'=>$host_id)); 
  
//$pk主键,可以是一个也可以是一个集合,$attributes是要修改的字段的集合,$condition条件,$params传入的值 
Post::model()->updateByPk($pk,$attributes,$condition,$params); 
$count=Admin::model()->updateByPk(1,array('username'=>'admin','password'=>'admin')); 
$count=Admin::model()->updateByPk(array(1,2),array('username'=>'admin','password'=>'admin'),'username=:name',array(':name'=>'admin')); 
if($count>0){echo "修改成功"; }else{echo "修改失败"; } 
  
Post::model()->updateCounters($counters,$condition,$params); 
$count=Admin::model()->updateCounters(array('status'=>1),'username=:name',array(':name'=>'admin')); 
if($count> 0){ echo "修改成功"; }else{echo "修改失败"; } 
//array('status'=>1)代表数据库中的admin表根据条件username='admin',查询出的所有结果status字段都自加1 
六、删除 
//deleteAll 
Post::model()->deleteAll($condition,$params); 
$count= Admin::model()->deleteAll('username=:name and password=:pass',array(':name'=>'admin',':pass'=>'admin')); 
$count= Admin::model()->deleteAll('id in("1,2,3")');//删除id为这些的数据 
if($count>0){echo"删除成功"; }else{echo "删除失败"; } 
  
//deleteByPk 
Post::model()->deleteByPk($pk,$condition,$params); 
$count= Admin::model()->deleteByPk(1); 
$count=Admin::model()->deleteByPk(array(1,2),'username=:name',array(':name'=>'admin')); 
if($count>0){echo "删除成功"; }else{echo "删除失败"; }

直接数据库操作

查询

//createCommand(执行原生的SQL语句) 
$sql= "SELECT u.account,i.* FROM sys_user as u left join user_info as i on u.id=i.user_id"; 
$rows=Yii::$app->db->createCommand($sql)->query(); 
foreach($rows as $k => $v){ 
  echo$v['add_time']; 
} 
 
查询返回多行: 
 
$command = $connection->createCommand('SELECT * FROM post'); 
$posts = $command->queryAll(); 
返回单行: 
 
$command = $connection->createCommand('SELECT * FROM post WHERE id=1'); 
$post = $command->queryOne(); 
查询多行单值: 
 
$command = $connection->createCommand('SELECT title FROM post'); 
$titles = $command->queryColumn(); 
查询标量值/计算值: 
 
$command = $connection->createCommand('SELECT COUNT(*) FROM post'); 
$postCount = $command->queryScalar();

更新

$command = $connection->createCommand('UPDATE post SET status=1 WHERE id=1'); 
$command->execute();

插入更新删除

// INSERT 
$connection->createCommand()->insert('user', [ 
  'name' => 'Sam', 
  'age' => 30, 
])->execute(); 
 
// INSERT 一次插入多行 
$connection->createCommand()->batchInsert('user', ['name', 'age'], [ 
  ['Tom', 30], 
  ['Jane', 20], 
  ['Linda', 25], 
])->execute(); 
 
// UPDATE 
$connection->createCommand()->update('user', ['status' => 1], 'age > 30')->execute(); 
 
// DELETE 
$connection->createCommand()->delete('user', 'status = 0')->execute();

事务

//事务的基本结构(多表更新插入操作请使用事务处理) 
$dbTrans= Yii::app()->db->beginTransaction(); 
try{ 
  $post= new Post; 
  $post->'title'= 'Hello dodobook!!!'; 
  if(!$post->save())throw newException("Error Processing Request", 1); 
  $dbTrans->commit(); 
// $this->_end(0,'添加成功!!!'); 
}catch(Exception$e){ 
  $dbTrans->rollback(); 
// $this->_end($e->getCode(),$e->getMessage());

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
关于文本留言本的分页代码
Oct 09 PHP
php zend 相对路径问题
Jan 12 PHP
php strlen mb_strlen计算中英文混排字符串长度
Jul 10 PHP
初品cakephp 入门基础
Feb 16 PHP
PHP数组传递是值传递而非引用传递概念纠正
Jan 31 PHP
深入解析php之sphinx
May 15 PHP
PHP5中实现多态的两种方法实例分享
Apr 21 PHP
php smarty truncate UTF8乱码问题解决办法
Jun 13 PHP
php基于curl扩展制作跨平台的restfule 接口
May 11 PHP
php三元运算符知识汇总
Jul 02 PHP
php mailer类调用远程SMTP服务器发送邮件实现方法
Mar 04 PHP
PHP实现微信退款的方法示例
Mar 26 PHP
利用PHP抓取百度阅读的方法示例
Dec 18 #PHP
详解PHP数据压缩、加解密(pack, unpack)
Dec 17 #PHP
Yii2中datetime类的使用
Dec 17 #PHP
php生成二维码图片方法汇总
Dec 17 #PHP
PHP二维数组去重算法
Dec 17 #PHP
php格式化时间戳
Dec 17 #PHP
PHP生成唯一ID之SnowFlake算法
Dec 17 #PHP
You might like
第五章 php数组操作
2011/12/30 PHP
ThinkPHP模板之变量输出、自定义函数与判断语句用法
2014/11/01 PHP
PHP字符串word末字符实现大小写互换的方法
2014/11/10 PHP
php数组去除空值函数分享
2015/02/02 PHP
实例化php类时传参的方法分析
2020/06/05 PHP
Jquery 滑入滑出效果实现代码
2010/03/27 Javascript
javascript下数值型比较难点说明
2010/06/07 Javascript
js实现字符串的16进制编码不加密
2014/04/25 Javascript
Javascript数组操作函数总结
2015/02/05 Javascript
JS简单编号生成器实现方法(附demo源码下载)
2016/04/05 Javascript
jQuery使用each方法与for语句遍历数组示例
2016/06/16 Javascript
nodejs和php实现图片访问实时处理
2017/01/05 NodeJs
jQuery代码实现实时获取时间
2017/01/29 Javascript
Node.js中Bootstrap-table的两种分页的实现方法
2017/09/18 Javascript
利用Javascript实现一套自定义事件机制
2017/12/14 Javascript
angular 组件通信的几种实现方式
2018/07/13 Javascript
Vue.js实现数据响应的方法
2018/08/13 Javascript
node静态服务器实现静态读取文件或文件夹
2019/12/03 Javascript
vant组件中 dialog的确认按钮的回调事件操作
2020/11/04 Javascript
[02:40]DOTA2英雄基础教程 炼金术士
2013/12/23 DOTA
Python3 模块、包调用&路径详解
2017/10/25 Python
Python 3.x 安装opencv+opencv_contrib的操作方法
2018/04/02 Python
python找出完数的方法
2018/11/12 Python
Python文件如何引入?详解引入Python文件步骤
2018/12/10 Python
Python爬虫实现爬取百度百科词条功能实例
2019/04/05 Python
Python中的self用法详解
2019/08/06 Python
使用IPython或Spyder将省略号表示的内容完整输出
2020/04/20 Python
Python爬虫工具requests-html使用解析
2020/04/29 Python
python3实现语音转文字(语音识别)和文字转语音(语音合成)
2020/10/14 Python
HTML5离线应用与客户端存储的实现
2018/05/03 HTML / CSS
奥地利体育网上商店:Gigasport
2019/10/09 全球购物
2014自主招生自荐信策略
2014/01/27 职场文书
2014年消防工作实施方案
2014/02/20 职场文书
简历中个人自我评价分享
2014/03/15 职场文书
志愿者活动总结
2014/04/28 职场文书
Win11电脑显示本地时间与服务器时间不一致怎么解决?
2022/04/05 数码科技