一、以createCommand方式:

// YII2中通过createCommand来处理数据库

// 查询多条记录

// {{%user}} 表示如果设置了表前缀,YII会自动帮你替换

$data1 = YII::$app->db->createCommand('select * from {{%user}}')->queryAll();

// 查询一条记录

// createCommand的第二个参数可以进行参数绑定

$data2 = YII::$app->db->createCommand('select * from {{%user}} where id=:id', ['id' => 2])->queryOne();

// 返回一列(第一列)数据

$data3 = YII::$app->db->createCommand('select name from {{%user}}')->queryColumn();

// 返回一个标量值,常用于统计

$data4 = YII::$app->db->createCommand('select count(*) as cnt from {{%user}}')->queryScalar();

// 绑定参数,防止SQL注入问题

// bindValue绑定一个参数

$data5 = YII::$app->db->createCommand('select * from {{%user}} where id=:id')

->bindValue(':id', 3)

->queryOne();

// 绑定多个参数

$data6 = YII::$app->db->createCommand('select * from {{%user}} where id=:id and name=:name')

->bindValues([':id' => 5, ':name' => 'eee'])

->queryOne();

// 绑定参数引用

$id = 7;

$data7 = YII::$app->db->createCommand('select * from {{%user}} where id=:id')

->bindParam(':id', $id)

->queryOne();

// 执行非查询语句

$data8 = YII::$app->db->createCommand('update {{%user}} set name=:name where id=:id')

->bindValues([':name' => 'abcdef', ':id' => 8])

->execute();

// 当然,我们也可以用更加简便的方法

// insert()插入

$data9 = YII::$app->db->createCommand()->insert('{{%user}}', [

'name' => 'test',

'sex' => 1,

'age' => 28,

])->execute();

// batchInsert()批量插入

$data10 = YII::$app->db->createCommand()->batchInsert('{{%user}}', ['name', 'sex', 'age'], [

['111', 1, 11],

['222', 1, 22],

])->execute();

// update()更新

$data11 = YII::$app->db->createCommand()->update('{{%user}}', [

'name' => '1242143214'

], 'id=:id', ['id' => 10])->execute();

// delete()删除

$data12 = YII::$app->db->createCommand()->delete('{{%user}}', 'id=:id', ['id' => 11])->execute();

// 执行事务

$trans = YII::$app->db->beginTransaction();

try {

YII::$app->db->createCommand()->update('{{%user}}', ['age' => 12], 'id=:id', ['id' => 13])->execute();

YII::$app->db->createCommand()->update('{{%user}}', ['age' => 22], 'id=:id', ['id' => 14])->execute();

$trans->commit();

} catch (\Exception $e) {

//如果语句中有一个执行失败,那么就将回滚

$trans->rollBack();

throw $e;

}

// 获取表的定义信息

$info = YII::$app->db->getTableSchema('{{%user}}');

yii mysql 操作数据库_YII2中操作数据库的方式相关推荐

  1. 用软件创建一个mysql的数据库_JSP中的数据库操作(1):MySQL数据库创建及管理...

    本文目录顺序: 安装MySQL MySQL管理软件SQLYog Enterprise --30天试用期到期解决方法 使用SQLYog Enterprise建立数据库 MySQL的各项参数 1. 安装M ...

  2. yii mysql 查询 类型转换_yii2.0数据库查询修改等方法

    yii2.0学习有一段时间了,给大家分享一下一些简单的查询等如何操作. 查询:(这里最前面的Test是引用的模型名) Test::find()->all();此方法返回所有数据: Test::f ...

  3. vb mysql 表格显示,在VB中编辑数据库和电子表格

    在VB50中有很多功能强大的控件,其中数据控件与一些绑定控件(如文本框,图片框及 ActiveX控件)的相互协作,能够方便地实现对各种数据库记录.表格乃至电子表格的浏览和编辑操作. 下面介绍实例,其 ...

  4. java实现 mysql 身份认证,java-从Filter中的数据库对用户进行身份验证是一种好习惯吗?...

    我正在为Android App创建Rest API(Spring Boot项目).从数据库对用户进行身份验证的理想方法应该是什么? 1.在控制器类中查询数据库 2.在过滤器类中查询数据库 3.使用Sp ...

  5. python mysql数据库_Python3中操作MySQL数据库

    0.安装 pip install pymysql 1.打开数据库连接 import pymysql db = pymysql.connect(host="数据库地址", user= ...

  6. java mysql 回滚_Java 中对数据库操作时的 回滚

    Connection conn=null; conn.rollback()就可以回滚 //用jdbc连接数据库 //举例子,比如你在写一个级联删除的方法的时候,为了保证数据完整性,删除的时候一定要确定 ...

  7. yii mysql 查询 类型转换_Yii2.0 API改造(返回数据库对应字段数据类型)

    namespace common\ext;useYii;useyii\base\InvalidConfigException;useyii\base\NotSupportedException;use ...

  8. mysql 程序迁移_如何从MySQL数据库程序中迁移数据库文件

    WordPress中文社区发现,很多时候我们在开发WordPress主题的时候,为了方便我们一般都会在自己的本地搭建的服务器环境中开发,比如wampserver或者phpsduty之类的,时间久了,本 ...

  9. hive mysql hdfs关系_Hive中的数据库、表、数据与HDFS的对应关系

    1.hive数据库 我们在hive终端,查看数据库信息,可以看出hive有一个默认的数据库default,而且我们还知道hive数据库对应的是hdfs上面的一个目录,那么默认的数据库default到底 ...

最新文章

  1. 轻量应用服务器MySQL远程连接踩坑
  2. python中是干嘛的-python中def是做什么的
  3. 项目进度管理:定义活动
  4. OpenCV将GIS数据加载到OpenCV容器中的实例(附完整代码)
  5. 破云里步重华为什么说自己姓薛_都说虎毒不食子,但猫咪为什么会吃掉自己的孩子呢...
  6. 《博德之门 3》究竟有多「DnD」?
  7. discuz邮件设置PHP,Discuz!6.0—如何配置发送邮件的参数
  8. (网页)swiper.js轮播图插件
  9. mysql to_minute_mysql的时间转化
  10. 全球金融科技发明专利排行榜(TOP20)
  11. elastic search与mysql的数据同步
  12. 恢复触摸板功能的方法
  13. 音乐类Demo资源大全
  14. Java DataStore 封装代码
  15. JSP 创建 CRUD 示例 MyBatis DAO 用于数据库JSTL 用于遍历记录
  16. 微信小程序:微擎开发飞鹅打印机配置
  17. 如何获取侧面加载的应用程序以显示在Fire Tablets的FreeTime配置文件中
  18. OpenState安装及 Port Knocking 实验
  19. int转long Long型
  20. tensoflow2.6训练自己的图像分类

热门文章

  1. xml文件中若没有子节点,则删除文件
  2. 2018 ACM-ICPC World Finals - Beijing F.Go with the Flow
  3. python3 开发面试题(面向对象)6.6
  4. 在maven 2工程中加入iTextAsian支持(maven添加自定义jar包到本地仓库)
  5. centos搭建git服务
  6. High ASCII字符从bat文件到dos控制台的转化问题
  7. nginx的gzip压缩
  8. SQL 去除重复、获取最新记录
  9. Ogre学习笔记Basic Tutorial 前四课总结
  10. SOA的十大技术理论体系