yii操作数据库的三种方式

发布时间 - 2020-02-17 00:00:00    点击率:

一、执行原生太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();

(相关教程推荐:yii框架)

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

想学习更多编程相关内容,请关注编程教程栏目!


# yii  # 可以使用  # 是一个  # 几个  # 相关内容  # 我们可以  # 可以通过  # 重写  # 成为一个  # 但它  # 想学 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤  Laravel如何实现密码重置功能_Laravel密码找回与重置流程  Laravel如何创建自定义中间件?(Middleware代码示例)  HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】  Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境  如何快速查询网址的建站时间与历史轨迹?  Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程  如何在搬瓦工VPS快速搭建网站?  javascript基本数据类型及类型检测常用方法小结  如何注册花生壳免费域名并搭建个人网站?  Laravel如何使用Passport实现OAuth2?(完整配置步骤)  北京的网站制作公司有哪些,哪个视频网站最好?  JS中页面与页面之间超链接跳转中文乱码问题的解决办法  如何在宝塔面板中修改默认建站目录?  Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  南京网站制作费用,南京远驱官方网站?  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  Laravel怎么实现微信登录_Laravel Socialite第三方登录集成  利用JavaScript实现拖拽改变元素大小  php做exe能调用系统命令吗_执行cmd指令实现方式【详解】  如何实现javascript表单验证_正则表达式有哪些实用技巧  Laravel的Blade指令怎么自定义_创建你自己的Laravel Blade Directives  EditPlus中的正则表达式实战(5)  Laravel如何实现事件和监听器?(Event & Listener实战)  打造顶配客厅影院,这份100寸电视推荐名单请查收  Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  英语简历制作免费网站推荐,如何将简历翻译成英文?  如何在建站主机中优化服务器配置?  Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践  潮流网站制作头像软件下载,适合母子的网名有哪些?  浅谈redis在项目中的应用  Python自动化办公教程_ExcelWordPDF批量处理案例  Laravel如何与Docker(Sail)协同开发?(环境搭建教程)  如何在阿里云虚拟服务器快速搭建网站?  php打包exe后无法访问网络共享_共享权限设置方法【教程】  专业商城网站制作公司有哪些,pi商城官网是哪个?  瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口  Python面向对象测试方法_mock解析【教程】  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  深入理解Android中的xmlns:tools属性  Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置  Laravel如何创建自定义Artisan命令?(代码示例)  零服务器AI建站解决方案:快速部署与云端平台低成本实践  如何快速配置高效服务器建站软件?  Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲  laravel怎么配置Redis作为缓存驱动_laravel Redis缓存配置教程  如何快速搭建高效可靠的建站解决方案?