博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Yii框架操作数据库的几种方式与mysql_escape_string
阅读量:7176 次
发布时间:2019-06-29

本文共 1352 字,大约阅读时间需要 4 分钟。

一、Yii操作数据库的几种选择 

1,PDO方式。 
$sql = "";//原生态sql语句 
xx::model()->dbConnection->createCommand($sql)->execute(); 


2,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 的方法实现。虽然此方法看起来很诱人, 但它常常引起混淆,冲突 

和比如列名大小写敏感的问题。 



3,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(); 



二、Yii操作数据库的几种选择与mysql_escape_string方法 
mysql_escape_string是转义sql中的特殊字符。 
1,创建记录时 
当直接执行sql时,需要加mysql_escape_string方法。 
当使用yii框架式,不需要加(因为Yii已经添加验证)。 

2,查询记录时 
当直接执行sql时,需要加mysql_escape_string方法。 
当使用yii框架式,如果在find中直接拼接sql,则也需要添加,如果使用param数组方式,不需要加(因为Yii已经添加验证)。 

转载地址:http://babzm.baihongyu.com/

你可能感兴趣的文章
jni native macOS
查看>>
shell命令xargs解析
查看>>
转载:onCreate()方法中的参数Bundle savedInstanceState 的意义用法
查看>>
android 补间动画帧动画
查看>>
JQUERY实现非叠加式的搜索框提示
查看>>
更新Maven的本地库
查看>>
HTML插入SWF
查看>>
POI 导入excel 代码记录 方便以后粘贴
查看>>
Ideal设置编码格式
查看>>
Spring分页实现PageImpl<T>类
查看>>
jQuery源码分析随笔
查看>>
在Hboxlayout中组件的显示比例
查看>>
应用上架被拒2.1问题
查看>>
针对vue的配置文件
查看>>
yum 源
查看>>
tcpdump详解
查看>>
android自动化测试工具之DroidPilot
查看>>
winfrom 界面编辑之疑难杂症
查看>>
pdo知识点1
查看>>
导出函数与未导出函数
查看>>