对thinkphp数据库操作的片段理解
发布:smiling 来源: PHP粉丝网 添加日期:2014-04-11 17:31:16 浏览: 评论:0
thinkphp 操作数据库有三个类:Db.class.php,DbMysql.class.php,Model.class.php
1.控制器中实例化数据库模型
2.调用数据库模型类中的方法(拿方法add来示例)
3.数据库模型类中方法调用DbMysql.class.php 类中的方法,但实际上DbMysql.class.php 继承了Db.class.php
实例化模型类就操作了很多操作,比如连接数据库.
$user=M('User');
$user->data($data)->add();
就这两步过程具体是怎么在执行呢?
一:在model中构造函数,执行了如下的操作
获取数据库模型的名称,获取数据库的相关信息,如表名,表前缀,最后再调用model里面的db方法操作数据库的连接
二:默认此时已经连接了数据库,那么add()这个方法具体做了些什么事情?
add($data='',$options=array(),$replace=false){}
它做了三件事情:
1.分析add方法里面是否传递了参数
(1).如果$data为空,获取当前对象的值,即data()方法返回的值
(2).如果为空报错
(3).将对象返回的值在赋给变量$data,赋给_facade($data)被它处理
2.分析表达式:(实际上就是获取数据库表表名,模型的信息,where条件,limit等来为拼凑sql语句作准备)
(1).获取表名,模型名(_parseOptions()该函数获取所有数据库操作的信息存入数组)
(2).拼凑sql:parseSql(),parseLock(),在Db.class.php中
通过获取的数据库sql相关信息,如where,limit,通过parsesql()函数处理替换SELECT%DISTINCT% %FIELD% FROM %TABLE%%JOIN%%WHERE%%GROUP%%HAVING%%ORDER%%LIMIT% %UNION%这个语句.
最后就变成了类似:SELECT * FROM `think_fenzhu` WHERE id=33 LIMIT 1
3.数据处理
4.执行插入操作(返回插入的id值)
执行插入理解:$this->db->add(); 调用Db.class.php 中的insert()方法
这是个人的片段理解,如有问题,请大牛谅解.
Tags: thinkphp 片段 数据库
- 上一篇:ThinkPHP入门心得
- 下一篇:ThinkPHP生成静态文件
相关文章
- ·ThinkPHP中自定义错误页面和提示页面 (2013-11-15)
- ·ThinkPHP中Ajax返回(2013-11-15)
- ·ThinkPHP中处理表单中注意(2013-11-15)
- ·ThinkPHP中I(),U(),$this->post()等函数(2013-11-15)
- ·ThinkPHP中公共函数路径和配置项路径的映射(2013-11-15)
- ·ThinkPHP中公共配置文件和各自项目中的配置文件组合(2013-11-15)
- ·ThinkPHP在控制器里的javascript代码不能执行解决方法(2013-11-29)
- ·ThinkPHP3.0略缩图不能保存到子目录(2013-12-03)
- ·thinkphp的循环结构(2014-01-10)
- ·thinkphp特殊标签使用(2014-01-10)
- ·thinkphp模板输出汇总(2014-01-10)
- ·thinkphp模板的赋值与替换(2014-01-10)
- ·thinkphp连贯操作(2014-01-10)
- ·thinkphp区间查询、统计查询、SQL直接查询(2014-01-10)
- ·thinkphp的普通查询与表达式查询(2014-01-10)
- ·RBAC类在ThinkPHP中的四种使用方法(2014-01-10)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)