thinkPHP框架中执行原生SQL语句的方法
发布:smiling 来源: PHP粉丝网 添加日期:2018-09-13 16:48:43 浏览: 评论:0
本文实例讲述了thinkPHP框架中执行原生SQL语句的方法。分享给大家供大家参考,具体如下:
怎样在thinkphp里面执行原生的sql语句?
- $Model = new Model();//或者 $Model = D(); 或者 $Model = M();
- $sql = "select * from `order`";
- $voList = $Model->query($sql);
只是需要new一个空的模型继承Model中的方法。
注意query是查功能,execute是增删改功能
查询和读取属性值的实例:
- $sql = "select * from goods";
- $Model = M();
- $result = $Model->query($sql);
- foreach ($result as $k=>$val){
- $goods_id = $val["goods_id"];
- }
tP的模型可以支持原生SQL操作,提供了query和execute两个方法,为什么原生SQL还要区分两个方法呢,原因有两个:
1、返回类型不同
query用于查询,返回的是数据集,和select或者findall一样,所以可以直接在模板里面使用volist标签输出query的查询结果
execute用于写操作,返回的是状态或者影响的记录数
2、读写统计需要
为了便于统计当前的数据读写次数,把数据库的读和写操作分开(对应的就是query和execute)
使用原生SQL很简单,我们甚至不需要实例化任何的模型,例如:
$Model = new Model(); // 实例化一个空模型
下面的方法是等效的
$Model = D();// 或者 $Model = M();
下面执行原生SQL操作
$Model->query('select * from think_user where status=1');
$Model->execute('update think_user set status=1 where id=1');
如果你实例化了某个模型,仍然可以执行原生SQL操作,不受影响,例如:
$User = D('User');
$User->query('select * from think_user where status=1');
$User->execute('update think_user set status=1 where id=1');
在这种情况下面,我们可以简化SQL语句的写法,例如:
$User->query('select * from __TABLE__ where status=1');
$User->execute('update __TABLE__ set status=1 where id=1');
系统会自动把__TABLE__替换成当前模型对应的数据表名称,实际的数据表由模型决定。
通常来说,我们都是使用原生SQL操作实现一些ORM和CURD比较难实现的操作,另外,如果SQL不复杂的话 原生SQL的效率和连贯操作的效率差别是微乎其微的,TP本身的ORM实现也是相当高效的。
Tags: 语句 框架 方法
相关文章
- ·ThinkPHP模板中使用判断语句(2014-04-11)
- ·thinkphp多表查询语句(2014-04-12)
- ·ThinkPHP框架获取最后一次执行SQL语句及变量调试简单操作示例(2018-11-14)
- ·ThinkPHP框架的九大特点(2014-04-11)
- ·在ThinkPHP 框架中快捷键M和D的不同之处(2014-04-11)
- ·Thinkphp框架学习(2014-04-11)
- ·nginx下使用ThinkPHP框架rewrite以及二级目录问题(2014-04-12)
- ·php thinkphp 框架快速入门(2014-04-12)
- ·对thinkphp框架编程中,ajax与php的响应过程讲解 (2014-04-12)
- ·ThinkPHP框架使用Zend ACL权限包(2014-04-21)
- ·ThinkPhp框架学习---框架搭建(2014-07-23)
- ·Thinkphp框架实现多文件上传实现代码(2014-09-21)
- ·不用封装 SQL, HTML 等领域语言了吧?(2014-10-24)
- ·利用thinkphp框架构建网站的执行流程详细介绍(2014-11-20)
- ·phpQuery ------实战应用thinkphp框架(2014-11-20)
- ·thinkphp框架 实现注册登录程序(2015-09-30)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)