ThinkPHP--各种查询条件设置

各种查询条件设置

$obj = D();  创建对象

$obj -> select();  查询数据

select  字段,字段  from  表名  where 条件  group 字段 having  条件   order 排序  limit 限制条数;

SELECT%DISTINCT%%FIELD%FROM %TABLE%%JOIN%%WHERE%%GROUP%%HAVING%%ORDER%%LIMIT% %UNION%%COMMENT%

 

$obj -> field(字段,字段);  查询指定字段

$obj -> table(数据表);   设置具体操作数据表

$obj -> where(参数);   参数就是正常sql语句where后边的条件信息

例如:“goods_price >100 and  goods_name like ‘三%’”)

$obj -> group(字段);  根据字段进行分组查询

$obj -> having(参数条件);  having 条件设置

$obj -> order(‘price  desc/asc’)  排序查询

$obj -> limit([偏移量,]条数)  限制查询的条数

 

sql语句里边具体的条件设置在tp框架model模型里边体现为具体的方法操作

 

以上方法理论上是父类Model的对应方法

父类model具体存在方法:   field()  where()   limit()

还有一些方法在__call()自动调用函数里边: table()  group()  order()  having()

__call()魔术方法里边会判断当前的执行方法是否是一个method属性的元素信息,如果存在就会执行执行

 

以上多个方法是同时使用多个进行条件显示(并且没有顺序要求)

$obj -> limit(5)->field(‘id,name’)->order(‘price asc’) -> table(‘sw_goods’)->select();

以上许多方法执行没有顺序要求,许多方法执行后都是把具体的参数赋予到model属性options里边,最后根据options拼装sql语句。

 


select()方法原理追踪


初学者如需购买thinkphp程序(包括前后台),加个人微信LBXZFR2013


微信扫描关注“公众号” 有惊喜



### ThinkPHP 查询构建器条件语法示例 在 ThinkPHP 中,`where` 方法是最常用于查询条件设置的方法之一。它支持多种类型的条件表达式,包括字符串条件、数组条件以及 `exp` 表达式等。 #### 字符串条件 当使用字符串作为查询条件时,可以直接传递 SQL 片段到 `where` 方法中。例如: ```php $User = M('User'); // 实例化 User 模型 $result = $User->where('status=1 AND id>0')->select(); ``` 此代码表示查询状态为 1 并且 ID 大于 0 的记录[^1]。 --- #### 数组条件 除了字符串外,还可以通过数组来定义更复杂的查询条件。以下是常见的数组条件形式及其含义: ##### 基本键值对 ```php $map['name'] = 'thinkphp'; $map['status'] = 1; $result = $User->where($map)->select(); ``` 这相当于执行如下 SQL: ```sql SELECT * FROM user WHERE name='thinkphp' AND status=1; ``` ##### 使用表达式 可以通过指定特殊的关键字(如 `_string`, `_query`, 或者自定义运算符)实现更多功能。例如: ```php $map['age'] = array('egt', 20); // egt 表示大于等于 (>=) $result = $User->where($map)->select(); ``` 该语句会生成以下 SQL: ```sql SELECT * FROM user WHERE age >= 20; ``` 完整的 TP 运算符对照表可参考文档说明[^2]。 --- #### 综合表达式 (`exp`) 对于一些无法简单用键值对描述的复杂场景,可以借助 `exp` 关键字。`exp` 可以嵌入任意合法的 SQL 语法片段,比如调用数据库内置函数或者处理字段间的关系计算。 下面是一个典型的例子——更新某篇文章的点击次数并保存更改: ```php $Dao = M("Article"); $data['id'] = 10; $data['counter'] = array('exp', 'counter+1'); $Dao->save($data); ``` 这段代码的作用是对 ID 为 10 的文章增加一次访问计数[^5]。 如果需要在查询中应用类似的逻辑,则可以用作过滤条件的一部分: ```php $condition['create_time'] = array('exp', '> NOW() - INTERVAL 7 DAY'); $list = $Model->where($condition)->select(); ``` 这里实现了筛选最近七天创建的文章列表的功能。 --- #### 高级特性:组合查询 ThinkPHP 支持多层嵌套和逻辑运算符连接多个子条件。例如: ```php $map['_logic'] = 'OR'; // 设置顶层逻辑关系为 OR $map[] = array('title', 'like', '%关键词%'); $map[] = array('content', 'like', '%关键词%'); $result = $Model->where($map)->select(); ``` 上述代码将查找标题或内容中含有特定关键字的所有记录。 --- ### 总结 以上展示了如何利用 ThinkPHP 提供的强大查询机制快速构建灵活高效的数据库交互接口。无论是简单的相等判断还是涉及日期范围、聚合统计等功能的需求都能轻松满足。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值