yii2 数据库和ActiveRecord
Yii2数据库和 ActiveRecord 类
1、在 common/config/main-local.php 里面配置数据账号和密码。
2、ActiveRecord(活动记录,简称AR类),提供了一套面向对象的接口,用以访问数据库中的数据
- 一个AR类关联一张数据表,每个AR对象对应表中的一行;
- AR类的属性,对应为数据库中的列
- 可以以面向对象的方式来操纵数据库中的数据,这样就不用谢 sql 语句来实现数据库的访问。
- find() 方法返回一条记录;
$model = Post::find()->where(['id'=>1])->one();
$model = Post::findOne(1);
- find() 方法返回所有记录;
$model = Post::find()->where(['status'=>1])->all();
$model = Post::findAll(['status'=>1]);
$total = User::find()->count(); // 查询总数(count(*))
3、ActiveQueryInterface 常用方法:
- all() 、one() --------- 执行查询,并返回 AR 对象
- orderBy()、andOrderBy() --------- 排序
- count() --------- 返回符合查询条件的记录数
- limit() --------- 取出查询结果的条数
- with() --------- 指定关联表的字段
- where()、andWhere()、orWhere() --------- 查询条件
4、where() 查询条件的写法:
| where 参数的写法 | sql 语句 | |
| and | ['and','id=1','id=2'] | id=1 AND id=2 |
| or | ['or','id=1','id=2'] | id=1 OR id=2 |
| in | ['in','id',[1,2,3]] | IN(1,2,3) |
| between | ['between','id',1,10] | id BETWEEN 1 AND 10 |
| like | ['like','name',['test','sample']] | name LIKE '%test%' AND name LIKE '%sample%' |
| 比较 | ['>=','id',10] | id >= 10 |
5、findBySql()
$sql = "SELECT * FROM post WHERE status = 1";
$post = Post::findBySql($sql) -> all();
6、CRUD 操作数据
AR 提供下面这些方法来实现插入、更新、删除等功能
a、yii\db\ActiveRecord::insert() // 插入
$customer = new Customer();
$customer -> name = 'Carroll';
$customer -> email = 'Carroll@qq.com'
$customer -> save(); // 等同于 $customer -> insert()
b、yii\db\ActiveRecord::update() // 更新
$customer = Customer::findOne($id);
$customer -> email = '123456@qq.com'
$customer ->save(); // 等同于 $customer -> update()
c、yii\db\ActiveRecord::delete() // 删除
$customer = Customer::findOne($id);
$customer -> delete();
d、yii\db\ActiveRecord::save() // 可同时替代 insert() 和 update(),开发中常用 save()方法
7 、ActiveRecord 的生命周期
| 方法 | 生命周期 | 事件 |
| new() | 1、constructor | |
| 2、init() | EVENT_INIT | |
| find() | 1、constructor | |
| 2、init() | EVENT_INIT | |
| 3、afterFind() | EVENT_AFTER_FIND | |
| save() | 1、beforeValidate() | EVENT_BEFORE_VALIDATE |
| 2、执行数据验证,如通不过,则第三部后面的步骤会被略过 | ||
| 3、afterValidate() | EVENT_AFTER_VALIDATE | |
| 4、beforeSave() | EVENT_BEFORE_INSERT or EVENT_BEFORE_UPDATE | |
| 5、执行数据插入或修改 | ||
| 6、afterSave() | EVENT_AFTER_INSERT or EVENT_AFTER_UPDATE | |
| delete() | 1、beforeDelete() | EVENT_BEFORE_DELETE |
| 2、执行数据删除 | ||
| 3、afterDelete() | EVENT_AFTER_DELETE | |
| refresh() | 1、afterRefresh() | EVENT_AFTER_REFRESH |
可以根据 ActiveRecord 的什么周期来重写方法,注入自己的代码控制流程
例如重写beforeSave(),如果这个方法执行后的结果为 false,后面的步骤就不会执行
/**
* @purpose : 将数据插入时间和更新时间插入数据库
* @param bool $insert
* @return bool
*/
public function beforeSave($insert){
if(parent::beforeSave($insert)){ // 需要首先继承父类的 beforeSave()
if($insert){
$this->create_time = time();
$this->update_time = time();
}else{
$this->update_time = time();
}
return true;
}else{
return false;
}
}
查询所有的记录:
$dataProvider->query->each() 查询当前页的数据:
$dataProvider->getModels() 获取当前模型的默认值:
$model = new Test();
$model->loadDefaultValues(); // 当前模型的默认值
Yii 中的回滚操作,此处用于 当遇到 try .... cache() 的时候
$transacton = Yii::$app->dbName->beginTransaction();
try{
...
$model->save();
$transacton->commit();
}cache(Exception $e){
$transacton->rollBack();
var_dump($e->getMessage());
}
注:本文为作者(44106-kangaroo) 看完魏羲教你学Yii2.0 视频后所记,如有转载请注明出处:http://www.cnblogs.com/chrdai/p/8006425.html
yii2 数据库和ActiveRecord的更多相关文章
- yii2 数据库查询
下面介绍一下 Yii2.0 对数据库 查询的一些简单的操作 User::find()->all(); 此方法返回所有数据: User::findOne($id); 此方法返回 主键 id=1 的 ...
- Yii2数据库分页操作方法介绍
本章节将介绍怎样怎样创建一个从数据表 country 中获取国家数据并显示出来的页面. 为了实现这个目标,你将会配置一个数据库连接.创建一个活动记录类,而且创建一个操作及一个视图. 贯穿整个章节,你将 ...
- YII2数据库依赖缓存
首先配置一下缓存,自己选择是用文件缓存还是数据库缓存等. 'cache' => [ 'class' => 'yii\caching\FileCache', ], 然后就可以通过 Yii:: ...
- yii2 数据库操作(转)
开始使用数据库首先需要配置数据库连接组件,通过添加 db 组件到应用配置实现("基础的" Web 应用是 config/web.php),DSN( Data Source Name ...
- YII2数据库操作出现类似Database Exception – yii\db\Exception SQLSTATE
yii2安装后,连接数据库,必须要安装pdo_mysql扩展
- Yii2 数据库操作汇总
对象操作 查询 //1.简单查询 $admin=Admin::model()->findAll($condition,$params); $admin=Admin::model()->fi ...
- Yii2 数据库查询汇总
1.基础查询 User::find()->all(); 此方法返回所有数据: User::findOne($id); 此方法返回 主键 id=1 的一条数据(举个例子): User::find( ...
- yii2 数据库操作详解(转载)
开始使用数据库首先需要配置数据库连接组件,通过添加 db 组件到应用配置实现("基础的" Web 应用是 config/web.php),DSN( Data Source Name ...
- yii2数据库简单操作
1.简单查询: one(): 根据查询结果返回查询的第一条记录. all(): 根据查询结果返回所有记录. count(): 返回记录的数量. sum(): 返回指定列的总数. average(): ...
随机推荐
- K/3 Cloud Web API接口说明文
K/3 Cloud Web API接口说明文 目的 三方集成,提供第三方系统与Cloud集成调用接口. 技术实现 HTTP + Json 提供标准接口 编号 名称 说明 1 Kingdee.BOS.W ...
- 【APUE | 03】文件I/O
博客链接: inux中的文件描述符与打开文件之间的关系 #include <stdio.h> #include <unistd.h> #include <sys/stat ...
- 一脸懵逼学习Hive的安装(将sql语句翻译成MapReduce程序的一个工具)
Hive只在一个节点上安装即可: 1.上传tar包:这个上传就不贴图了,贴一下上传后的,看一下虚拟机吧: 2.解压操作: [root@slaver3 hadoop]# tar -zxvf hive-0 ...
- 使用JDBC连接ElasticSearch6.3(ElasticSearch SQL JDBC)
使用JDBC连接ElasticSearch6.3(ElasticSearch SQL JDBC) https://blog.csdn.net/scgaliguodong123_/article/det ...
- WebApi参数传递实例
Get 1.基础数据类型 1.1方法只含有一个形参 (1)Get传值的本质是通过url字符串拼接(2)Get传递参数本质是url字符串拼接,Request-Head头部传递,Request-Body中 ...
- Tomcat模型结构
一.请求过程 Tomca的两大组件:Connecter和Container Connecter组件 1.Connecter将在某个指定的端口上侦听客户请求,接收浏览器的发过来的 tcp 连接请求,创建 ...
- 修改ini文件的批处理
用VBS更简单: vbs代码: On Error Resume Next Dim Fso,TxtFl,Str Set Fso = CreateObject("Scripting.FileSy ...
- Linux Centos7安装最新anslib
一.添加最新epel源 yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm 二.添加最 ...
- Vue 组件(上)转载
一.定义 组件:应用界面上一个个的区块. 自定义的HTML元素. 二.创建和注册 Vue.extend() 扩展,创建组件构造器 Vue.component()注册组件,2个参数,1为标签,2是组件构 ...
- 导入项目报错:Type Java compiler level does not match the version
1,导入项目报错一般是因为缺少jar包或者是jar包冲突 2,导入的jar包版本问题 3,环境需要重新修改,比如build path 中重新add libararies 遇到这种compiler环境问 ...