Yii操作数据库的3种方法

 更新时间:2014年03月11日 09:12:46   作者:  
这篇文章主要介绍了Yii操作数据库的3种方法,需要的朋友可以参考下
一、执行原生太SQL的PDO方式。
复制代码 代码如下:
$sql = "";//原生态sql语句
xx::model()->dbConnection->createCommand($sql)->execute();

二、Active Record方式
(1)New 方式
复制代码 代码如下:
$post=new Post;
$post->title='sample post';
$post->content='post body content';
$post->save();

(2)Criteria方式
也可以使用 $condition 指定更复杂的查询条件。 不使用字符串,我们可以让 $condition 成为一个 CDbCriteria 的实例,它允许我们指定不限于 WHERE 的条件。
复制代码 代码如下:
$criteria=new CDbCriteria;
$criteria->select='title';  // 只选择 'title' 列
$criteria->condition='postID=:postID';
$criteria->params=array(':postID'=>10);
$post=Post::model()->find($criteria);

一种替代 CDbCriteria 的方法是给 find 方法传递一个数组。 数组的键和值各自对应标准(criterion)的属性名和值,上面的例子可以重写为如下:
复制代码 代码如下:
$post=Post::model()->find(array(
    'select'=>'title',
    'condition'=>'postID=:postID',
    'params'=>array(':postID'=>10),
));

当一个查询条件是关于按指定的值匹配几个列时,我们可以使用 findByAttributes()。我们使 $attributes 参数是一个以列名做索引的值的数组。在一些框架中,此任务可以通过调用类似 findByNameAndTitle 的方法实现。虽然此方法看起来很诱人,但它常常引起混淆、冲突和比如列名大小写敏感的问题。
三、Query Builder 方式
复制代码 代码如下:
$user = Yii::app()->db->createCommand()
    ->select('id, username, profile')
    ->from('tbl_user u')
    ->join('tbl_profile p', 'u.id=p.user_id')
    ->where('id=:id', array(':id'=>$id))
    ->queryRow();

相关文章

  • php中实现进程锁与多进程的方法

    php中实现进程锁与多进程的方法

    这篇文章给大家介绍了单进程的情况的进程锁实现、进程锁实现多进程、进程锁在yii2中的实现以及杀死进程的命令,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-09-09
  • 自写的利用PDO对mysql数据库增删改查操作类

    自写的利用PDO对mysql数据库增删改查操作类

    这篇文章主要给大家介绍了关于自写的利用PDO对mysql数据库的增删改查操作类的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2018-02-02
  • PHP在linux上执行外部命令的方法

    PHP在linux上执行外部命令的方法

    下面小编就为大家带来一篇PHP在linux上执行外部命令的方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-02-02
  • phpmail类发送邮件函数代码

    phpmail类发送邮件函数代码

    前天要给网站做一个小功能,就是在用户留言的时候发邮件通知管理员。我们都知道在PHP里有一个mail函数,但是要求服务器要有邮件服务器的功能,比如简单的SMTP或者POP3。但是,如果我们的服务器没有这种功能,那么怎么办呢
    2012-02-02
  • PHP中Enum(枚举)用法实例详解

    PHP中Enum(枚举)用法实例详解

    这篇文章主要介绍了PHP中Enum(枚举)用法,结合实例形式较为详细的分析了php中Enum(枚举)的实现与使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-12-12
  • PHP实现自动登入google play下载app report的方法

    PHP实现自动登入google play下载app report的方法

    这篇文章主要介绍了PHP实现自动登入google play下载app report的方法,较为详细的讲述了登陆下载APP及对应的实现代码,具有不错的实用价值,需要的朋友可以参考下
    2014-09-09
  • php中RESTful API的使用方法详解

    php中RESTful API的使用方法详解

    RESTful API是一种软件架构风格,它将资源(Resource)作为核心概念,并通过一组统一的接口对资源进行操作,下面我们就来学习一下RESTful API在PHP中的具体使用吧
    2023-11-11
  • PHP实现的ID混淆算法类与用法示例

    PHP实现的ID混淆算法类与用法示例

    这篇文章主要介绍了PHP实现的ID混淆算法类与用法,结合实例形式分析了php针对数字基于位运算、位移等操作的加密解密相关实现技巧,需要的朋友可以参考下
    2018-08-08
  • php fread读取文件注意事项

    php fread读取文件注意事项

    php fread函数用于从文件中读取一定长度的字符,本文章向大家介绍fread读取文件的实例以及使用该函数读取文件需要注意的几个地方,需要的朋友可以参考一下。
    2016-09-09
  • php获取微信基础接口凭证Access_token

    php获取微信基础接口凭证Access_token

    这篇文章主要为大家详细介绍了php获取微信基础接口凭证Access_token,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08

最新评论