Thinkphp6支持命令行启动?thinkphp5资源控制器详解
本篇文章给大家谈谈Thinkphp6支持命令行启动,以及thinkphp5资源控制器详解对应的知识点,文章可能有点长,但是希望大家可以阅读完,增长自己的知识,最重要的是希望对各位有所帮助,可以解决了您的问题,不要忘了收藏本站喔。
一、thinkphp下MySQL数据库读写分离代码剖析
1、当采用原生态的sql语句进行写入操作的时候,要用execute,读操作要用query。
2、MySQL数据主从同步还是要靠MySQL的机制来实现,所以这个时候MySQL主从同步的延迟问题是需要优化,延迟时间太长不仅影响业务,还影响用户体验。
3、thinkphp核心类Thinkphp/library/Model.class.php中,query方法
4、调用Thinkphp/library/Think/Db/Driver/Mysql.class.php
5、*@parammixed$parse是否需要解析SQL
6、publicfunctionquery($sql,$parse=false){
7、if(!is_bool($parse)&&!is_array($parse)){
8、$sql=$this->parseSql($sql,$parse);
9、return$this->db->query($sql);
10、调用Thinkphp/library/Think/Db/Driver/Mysql.class.php
11、if(0===stripos($str,'call')){//存储过程查询支持
12、if(!$this->_linkID)returnfalse;
13、if($this->queryID){$this->free();}
14、$this->queryID=mysql_query($str,$this->_linkID);
15、if(false===$this->queryID){
16、$this->numRows=mysql_num_rows($this->queryID);
17、上面初始化数据库链接时,initConnect(false),调用Thinkphp/library/Think/Db/Db.class.php,注意false、true代码实现。true表示直接调用主库,false表示调用读写分离的读库。
18、protectedfunctioninitConnect($master=true){
19、$this->_linkID=$this->multiConnect($master);
20、if(!$this->connected)$this->_linkID=$this->connect();
21、protectedfunctionmultiConnect($master=false){
22、foreach($this->configas$key=>$val){
23、$_config[$key]=explode(',',$val);
24、$r=floor(mt_rand(0,C('DB_MASTER_NUM')-1));
25、if(is_numeric(C('DB_SLAVE_NO'))){//指定服务器读
二、thinkphp5资源控制器详解
1、要在命令行中使用PHP的话先将php.exe放入全局变量这样方便一些。然后在thinkphp5根目录下执行命令:
2、phpthinkmake:controllerapp\index\controller\Blog再注册一个资源路由:
3、Route::resource('blog','index/Blog');
关于Thinkphp6支持命令行启动,thinkphp5资源控制器详解的介绍到此结束,这篇文章只是小编的分享,并不能代表大家观点和客观事实,仅仅给大家作为参考交流学习哦!希望对大家有所帮助。
——————————————小炎智能写作工具可以帮您快速高效的创作原创优质内容,提高网站收录量和各大自媒体原创并获得推荐量,点击右上角即可注册使用
相关新闻推荐
- Thinkphp6的特性(thinkphp6隐藏入口文件怎么没用) 2023-12-05
- Thinkphp6支持命令行启动?thinkphp5资源控制器详解 2023-12-05
- Thinkphp6插件化教程,php中为什么用thinkphp框架开发会比较快 2023-12-05
- Thinkphp6 内容管理(thinkphp5怎么使用单元测试) 2023-12-05
- Thinkphp5防止外部访问(thinkphp如何根据域名跳转到其他目录页面) 2023-12-05
- Thinkphp5连接不上数据库 thinkphp5怎么同时连接mysql和sqlserver2种数据库 2023-12-05