服务器之家

服务器之家 > 正文

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

时间:2021-04-08 16:00     来源/作者:寻i

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

对象操作

查询

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
//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 "删除失败"; }

直接数据库操作

查询

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
//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();

更新

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

插入更新删除

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// 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();

事务

?
1
2
3
4
5
6
7
8
9
10
11
//事务的基本结构(多表更新插入操作请使用事务处理)
$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());

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:http://blog.csdn.net/xundh/article/details/45955195

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
Intellij idea2020永久破解,亲测可用!!!
Intellij idea2020永久破解,亲测可用!!! 2020-07-29
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
返回顶部