Yii如何使用数据库
1.Yii如何使用数据库
Yii通过数据库访问对象(Database Access Objects,简称DAO)来使用数据库的。
DAO建立在“PHP数据对象(PDO)之上,并提供一套面向对象的API来访问数据库”
2.数据库的连接
数据库的连接通常放在配置文件中,/common/config/main-local.php中。
'db' => [
'class' => 'yii\db\Connection',
'dsn' => 'mysql:host=localhost;dbname=yii2advanced',
'username' => 'root',
'password' => 'root',
'charset' => 'utf8',
],
这里表示会创建一个yii\db\Connection对象,并用这个对象访问数据库。
这个数据库连接对象的写法:Yii->$app->db
连接不同数据库的语句略微有些差异。

3,数据库查询(yii\db\Command)
用SQL查询语句来创建一个yii\db\Command的对象,调用对象的方法来执行SQL查询,返回值是字符型的数组。
$post = Yii::$app->db->createCommand('SELECT * FROM post')->queryAll();
SQL语句还可以绑定参数。
$post = Yii::$app->db->createCommand('SELECT * FROM post WHERE id=:id AND status=:status')
->bindValue(':id',$_GET['id'])
->bindValue(':status',2)
->queryOne();
4,yii\db\Command的优缺点
1,简单,只需要处理sql语句和数组就行了(优点)
2,高效,通过sql语句来查询数据库非常高效。(优点)
----------------------------------------------------------
1,不同的数据库系统的sql语句会有些差别,因此无法做到代码适用于多种数据库系统。(缺点)
2,用数组,而没有用到面向对象的方式来管理数据,代码难维护。(缺点)
3,如果不小心,会留下SQL注入这种不安全因素。(缺点)
5,ActiveRecord
(1)
ActiveRecord(活动记录,简称AR类)提供了一项面向对象的接口,可以访问数据库中的数据。
一个AR类关联一张数据表,每个AR对象对应表中的一行
AR对象的属性,对应数据库的列
可以直接以面向对象的方式来操纵数据库中的数据(AR把数据库和模型建立的联系),这样就不需要写SQL语句就能实现数据库的访问了。
(2)声明ActiveRecord类
通过继承yii\db\ActiveRecord基类来声明一个AR类,并实现tableName方法,返回与之相关联的数据表的名称
class Post extends \yii\db\ActiveRecord
{
/**
* @inheritdoc
*/
public static function tableName()
{
return 'post';
}
AR提供了两种方法来构建DB查询,返回AR对象。
yii\db\ActiveRecord::find()
$model = Post::find()->where(['id' => 1])->one();
$model = Post::find()->where([status" => 1])->all();
这两个方法的简便替换方法是:
$model = Post::findOne(1)
$models = Post::findAll(['status' => 1])
(3)更为复杂的查询就得求助于类参考手册了。通过查询,得到复杂的查询需要借助ActiveQueryInterface这个接口。
ActiveQueryInterface的常用方法:
举例说明:
$post = Post::find()->where(['AND',['status' => 2],['author_id => 1'],['like',"title",'yii2']])->orderBy('id')->all();
此外可以通过 yii\db\ActiveRecord::findBySql()来进行数据查询,不常用。
$sql = 'SELECT * FROM post where status=1';
$posts = Post::findBySql($sql)->all();
(4)访问列数据
AR对象的属性,对应为数据行的列
$model = Post::findOne(1);
echo $model->id;
echo $model->title;
------------------------
$model = Post::findAll(['status' => 1]);
foreach($model as $item)
{
echo $item->id;
echo $item->title;
}
(5)操作数据CRUD
AR提供下边这些方法来实现插入,更新和删除等功能
yii\db\ActiveRecord::insert()
yii\db\ActiveRecord::update()
yii\db\ActiveRecord::delete()
yii\db\ActiveRecord::save()

(6)AR查询关联数据
ActiveRecord类通过hasOne或者hasMany方法来建立两张表的关联关系。
hasOne用于多对一,一对一的情况;hasMany用于一对多的情况
建立关联关系后,就可以像访问自己的类数据一样便捷地去访问关联表数据。
Gii会根据数据库表之间的关联关系,自动生成建立类之间关联关系的代码。
例如:
$thePost->status0->name
$thePost->comments
-----------------------------------------
public function getStatus0()
{
return $this->hasOne(Poststatus::className(),['id' => 'status']);
}
-------------------------------------------------
public function getComments()
{
return $this->hasMany(Comment::className(),['post_id' => 'id'])
}
6,查询构建器QueryBuilder
1,什么是查询构建器
查询构建器也是建立在DAO基础之上的,可让你创建程序化的,DBMS无关的SQL语句,并且,这样创建的SQL语句,比原生的SQL语句更加易读。更安全。
2,使用查询构建器的步骤
(1)构建查询:创建一个yii\db\Query对象来代表一条SELECT SQL语句,然后通过调用一套可以串起来的方法,比如select方法,from方法,where方法等这些方法,构建出可以满足一定要求的查询条件。
(2)执行查询。执行yii\db\Query的一个查询方法从数据库当中检索数据。例如:all(),one(),column()等这些查询方法。
$allStatus = (new \yii\db\Query())
->select(['name','id'])
->from('poststatus')
->indexBy('id')
->column();
总结:

Yii如何使用数据库的更多相关文章
- Yii 框架里数据库操作详解-[增加、查询、更新、删除的方法 'AR模式']
public function getMinLimit () { $sql = "..."; $result = yii::app()->db-& ...
- 配置yii访问远程数据库
1.将hdp002的数据库放到hdp004后,发现yii出现找不到表messages的迹象.用hdp002远程登录hdp004后发现,原来是hdp004没有授权给hdp002,用下面的sql语句即可: ...
- Yii框架 多数据库、主从、读写分离
Yii是可以在配置文件里声明多个数据库连接,然后通过Yii::app()->db1,Yii::app()->db2...来访问它们,并且也实现了更高级(自动)的主从数据库功能. 最近因为一 ...
- Yii 2.0 数据库操作总结
1. 概述 操作数据库有2种方式: DAO(data access object),不安全 ORM(onject relational mapping) 2. DAO Yii::app()->d ...
- Yii框架操作数据库的几种方式与mysql_escape_string
一.Yii操作数据库的几种选择 1,PDO方式. $sql = "";//原生态sql语句 xx::model()->dbConnection->createComma ...
- Yii中的数据库事务的使用方法小结
在项目中遇到批量删除的地方一般会使用到事务,下面列举一个用法实例与大家分享. 查看代码 打印 01 <?php 02 $array=array( 03 0=>array('us ...
- sql这两个表和查询的组合yii通过使用数据库查询
sql两个表的组合查询 使用 join on 比如:两个表查询: select u.username, t.title from user u join task t on u.id = t.id; ...
- CSRF token 无法被验证. ----Yii连接数据库后数据库错误日志报错
CSRF token 无法被验证. 我使用的是mongodb+ yii1.1 What is CSRF, please see the details here. http://en.wikiped ...
- Yii MySQL修改数据库的数据
最新学习Yii框架,分享一些学习心得,适合初学者,大神请按ctrl + w //第一种方法 <?php /* * $id 代表主键,可以是一个也可以是一个集合. * $attributes 代表 ...
随机推荐
- linux nvme的那些workqueue
目前nvme三个常见的使用的workqueue ,主要有nvme_workq,nvme_rdma_wq ,nvme_fc_wq,下面一一描述一下初始化及使用的场景.分别对应于NVME over PCI ...
- FORTH 安装使用
body, table{font-family: 微软雅黑; font-size: 10pt} table{border-collapse: collapse; border: solid gray; ...
- 关于ls命令的实例
生活映射程序---------科技创造生活 ls 是Linux的常用命令之一直接使用 ls 命令的话只会列出对应的文件名ls -l 命令会显示文件和目录,包括文件类型,大小,修改日期和时间,权限信息等 ...
- Redis跟Spring整合,sentinel模式
普通模式整合 一.在pom.xml中引入redis的依赖 <dependency> <groupId>org.springframework.data</groupId& ...
- CentOS6.x机器安装Azure CLI2.0【1】
安装Azure CLI 2.0的前提是:机器中必须有 Python 2.7.x 或 Python 3.x.如果机器中没有其中任何一个Python版本,请及时安装 1.准备一台CentOS 6.9的机器 ...
- WebP 图片实践之路
我们会从三部分来聊聊webp这个话题. 什么是webp,它有什么用? 使用webp的常规方法以及优劣. 我们是如何用上webp的. PS:如果是对webp有一定了解的朋友,建议直接看第三部分.因为是讲 ...
- x64内核HOOK技术之拦截进程.拦截线程.拦截模块
x64内核HOOK技术之拦截进程.拦截线程.拦截模块 一丶为什么讲解HOOK技术. 在32系统下, 例如我们要HOOK SSDT表,那么直接讲CR0的内存保护属性去掉. 直接讲表的地址修改即可. 但是 ...
- JavaScript之点赞特效
在很多网站中登录后可以对你说喜欢的文章.图片之类的进行点赞,这个功能效果的实现就是我今天要写的东西.代码不长,但觉得还是很有用的,为 js 给用户交互体验上更加友好.在实现过程中,主要的思路有: 点赞 ...
- JavaScript中事件绑定的三种方式
JavaScript使得网页与用户友好交互,在使用 js 进行时间绑定的时候有三种绑定方式. 第一种:初学者以及普通写法 <div id="dom0"> <inp ...
- String 类的选择输出
package com.day_08.strings; /* * 通过API可知/String是在Java.lang包下的类,所以不用导包 */ public class StringDemo { p ...