
在配置文件设置属性:webb/config/main.php中添加persistent或者attributes属性;
检测是否成功启用长连接
可以调用frameworkdbCDbConnection.php下的getPersistent()函数,返回true为启用成功,false为启用失败;
如果使用了长连接而长期没有对数据库进行任何 *** 作,那么在timeout值后,mysql
server就会关闭此连接,而客户端在执行查询的时候就会得到一个类似于“MySQL server has gone away“这样的错误。
望采纳,谢谢!
一、执行原生太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()
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)