网站地图    收藏   

主页 > 后端 > thinkphp教程 >

对thinkphp数据库操作的片段理解 - Thinkphp

来源:自学PHP网    时间:2014-11-28 23:17 作者: 阅读:

[导读] thinkphp 操作数据库有三个类:Db class php,DbMysql class php,Model class php1 控制器中实例化数据库模型2 调用数据库模型类中的方法(...

对thinkphp数据库操作的片段理解

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()方法

这是个人的片段理解,如有问题,请大牛谅解.

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论