链式写法php,ThinkPHP框架SQL操纵链式写法道理(浅显易懂)_PHP开发框架教程

本文主要是介绍链式写法php,ThinkPHP框架SQL操纵链式写法道理(浅显易懂)_PHP开发框架教程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

下面由

thinkphp框架教程栏目给人人引见ThinkPHP框架SQL操纵链式写法道理,愿望对须要的朋侪有所协助!

b0d74e545940a17a400e6e86ea0cc51b.png

弁言

人人假如有口试频频不难发明,虽然国产的TP一向被人诟病。然则涓滴不能影响它在宽大企业中的开发遭到喜爱,壮大的社区,暴力有用细致的中文手册。有一个处所置信人人都不生疏,就是他的链式写法,链式写法的肯定程度上简化了SQL工作量。OK,是怎样完成的,那我们从面向对象入手,剖析链式写法的完成道理。

以下语句

$User->limit(10)->where('status=1')->select();

代码

我们晓得,面向对象的要领,能够返回多种数据范例,固然,也能够返回对象本身,所以我们能够应用这个特征来完成

class Test{

private $var = "";

public function Func(){

$this->var = "Var is change";

return $this;

}

}

$obj = new Test();

var_dump($obj);

var_dump($obj->Func());

打印出来的效果:

object(Test)[1]

private 'var' => string '' (length=0)

object(Test)[1]

private 'var' => string 'Var is change' (length=13)

不难发明:我们私有变量 发 生 了 改 变 。 也 就 是 说 , 我 们 obj->Func(),实行后,返回了一个带着$var = "Var is change"的对象。

$User->limit(10)->where('status=1')->select();

那末这个语句就不难理解了。 要领实行后,通报对象给下个要领,以此类推。

简朴的Select()完成

class UserModel{

private $field ="*";

private $tableName ="";

private $where ="";

private $order ="";

private $limit ="";

function field($field){

$this->field = $field;

return $this;

}

function table($tableName){

$this->table = $tableName;

return $this;

}

function order($order){

$this->order = "ORDER BY ".$order;

return $this;

}

function where($where){

$this->where = "WHERE ".$where;

return $this;

}

function limit($index, $limit = 0){

$this->limit = "LIMIT ".$index;

if($limit){

$this->limit.= ",{$limit}";

}

return $this;

}

function select(){

if(empty($this->tableName)){

$this->tableName = str_replace("Model", "", __CLASS__);//假如表名不指定,则猎取类名

}

$selectSql ="SELECT {$this->field}

FROM `{$this->tableName}`

{$this->where}

{$this->order}

{$this->limit}";

//组织SQL语句模版串

echo $selectSql;

//return mysql_query($selectSql); 实行拼接后的SQL语句

}

}

$user = new UserModel();

$user->where("`user` = 1")->order("`user` DESC")->limit(5)->select();?>

总结

思绪也许就是经由过程链式操纵要领,给SQL语句的各个前提赋值,然后到最后一步一致处置惩罚SQL语句。这里只是简朴地完成下道理,故意的同砚能够对要领参数多种范例推断,越发天真地赋前提。比方where要领能够传数组。然后也能够依照此思绪,做比方INSERT(),UPDATE(),DELETE()等等。这里只是举一反三,假如要越发深切相识链式写法,也能够看TP源码。

以上就是ThinkPHP框架SQL操纵链式写法道理(浅显易懂)的细致内容,更多请关注ki4网别的相干文章!

收藏 | 0

这篇关于链式写法php,ThinkPHP框架SQL操纵链式写法道理(浅显易懂)_PHP开发框架教程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/424729

相关文章

SQL注入漏洞扫描之sqlmap详解

《SQL注入漏洞扫描之sqlmap详解》SQLMap是一款自动执行SQL注入的审计工具,支持多种SQL注入技术,包括布尔型盲注、时间型盲注、报错型注入、联合查询注入和堆叠查询注入... 目录what支持类型how---less-1为例1.检测网站是否存在sql注入漏洞的注入点2.列举可用数据库3.列举数据库

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

Window Server创建2台服务器的故障转移群集的图文教程

《WindowServer创建2台服务器的故障转移群集的图文教程》本文主要介绍了在WindowsServer系统上创建一个包含两台成员服务器的故障转移群集,文中通过图文示例介绍的非常详细,对大家的... 目录一、 准备条件二、在ServerB安装故障转移群集三、在ServerC安装故障转移群集,操作与Ser

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的

windos server2022的配置故障转移服务的图文教程

《windosserver2022的配置故障转移服务的图文教程》本文主要介绍了windosserver2022的配置故障转移服务的图文教程,以确保服务和应用程序的连续性和可用性,文中通过图文介绍的非... 目录准备环境:步骤故障转移群集是 Windows Server 2022 中提供的一种功能,用于在多个

MySQL中时区参数time_zone解读

《MySQL中时区参数time_zone解读》MySQL时区参数time_zone用于控制系统函数和字段的DEFAULTCURRENT_TIMESTAMP属性,修改时区可能会影响timestamp类型... 目录前言1.时区参数影响2.如何设置3.字段类型选择总结前言mysql 时区参数 time_zon

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨