Yii操作数据库的3种方法
程序员文章站
2023-01-08 08:21:52
一、执行原生太sql的pdo方式。复制代码 代码如下:$sql = "";//原生态sql语句 xx::model()->dbconnection->creat...
一、执行原生太sql的pdo方式。
二、active record方式
(1)new 方式
(2)criteria方式
也可以使用 $condition 指定更复杂的查询条件。 不使用字符串,我们可以让 $condition 成为一个 cdbcriteria 的实例,它允许我们指定不限于 where 的条件。
一种替代 cdbcriteria 的方法是给 find 方法传递一个数组。 数组的键和值各自对应标准(criterion)的属性名和值,上面的例子可以重写为如下:
当一个查询条件是关于按指定的值匹配几个列时,我们可以使用 findbyattributes()。我们使 $attributes 参数是一个以列名做索引的值的数组。在一些框架中,此任务可以通过调用类似 findbynameandtitle 的方法实现。虽然此方法看起来很诱人,但它常常引起混淆、冲突和比如列名大小写敏感的问题。
三、query builder 方式
复制代码 代码如下:
$sql = "";//原生态sql语句
xx::model()->dbconnection->createcommand($sql)->execute();
xx::model()->dbconnection->createcommand($sql)->execute();
二、active record方式
(1)new 方式
复制代码 代码如下:
$post=new post;
$post->title='sample post';
$post->content='post body content';
$post->save();
$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);
$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),
));
'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();
->select('id, username, profile')
->from('tbl_user u')
->join('tbl_profile p', 'u.id=p.user_id')
->where('id=:id', array(':id'=>$id))
->queryrow();