首页技术文章正文

对thinkphp数据库操作的片段理解【黑马PHP培训】

更新时间:2019年08月01日 19时20分37秒 来源:黑马程序员论坛

黑马中级程序员课程

hinkphp  操作数据库有三个类: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()方法
这是个人的片段理解,如有问题,请大牛谅解.



推荐了解热门学科

java培训 Python人工智能 Web前端培训 PHP培训
区块链培训 影视制作培训 C++培训 产品经理培训
UI设计培训 新媒体培训 软件测试培训 Linux运维
大数据培训 智能机器人软件开发




传智播客是一家致力于培养高素质软件开发人才的科技公司“黑马程序员”是传智播客旗下高端IT教育品牌。自“黑马程序员”成立以来,教学研发团队一直致力于打造精品课程资源,不断在产、学、研3个层面创新自己的执教理念与教学方针,并集中“黑马程序员”的优势力量,针对性地出版了计算机系列教材50多册,制作教学视频数+套,发表各类技术文章数百篇。

传智播客从未停止思考

传智播客副总裁毕向东在2019IT培训行业变革大会提到,“传智播客意识到企业的用人需求已经从初级程序员升级到中高级程序员,具备多领域、多行业项目经验的人才成为企业用人的首选。”

中级程序员和初级程序员的差别在哪里?
项目经验。毕向东表示,“中级程序员和初级程序员最大的差别在于中级程序员比初级程序员多了三四年的工作经验,从而多出了更多的项目经验。“为此,传智播客研究院引进曾在知名IT企业如阿里、IBM就职的高级技术专家,集中研发面向中高级程序员的课程,用以满足企业用人需求,尽快补全IT行业所需的人才缺口。

何为中高级程序员课程?

传智播客进行了定义。中高级程序员课程,是在当前主流的初级程序员课程的基础上,增加多领域多行业的含金量项目,从技术的广度和深度上进行拓展“我们希望用5年的时间,打造上百个高含金量的项目,覆盖主流的32个行业。”传智播客课程研发总监于洋表示。




黑马程序员热门视频教程

Python入门教程完整版(懂中文就能学会) 零起点打开Java世界的大门
C++| 匠心之作 从0到1入门学编程 PHP|零基础入门开发者编程核心技术
Web前端入门教程_Web前端html+css+JavaScript 软件测试入门到精通


在线咨询 我要报名
和我们在线交谈!