ThinkPHP可以支持直接使用字符串作为查询条件

ThinkPHP可以支持直接使用字符串作为查询条件,但是大多数情况推荐使用数组或者对象来作为查询条件,因为会更加安全。

大理石平台哪家好

一、使用字符串作为查询条件

这是最传统的方式,但是安全性不高,例如:

  1. $User = M("User"); // 实例化User对象
  2. $User->where(‘type=1 AND status=1‘)->select();

最后生成的SQL语句是

  1. SELECT * FROM think_user WHERE type=1 AND status=1

采用字符串查询的时候,我们可以配合使用字符串条件的安全预处理机制。

二、使用数组作为查询条件

这种方式是最常用的查询方式,例如:

  1. $User = M("User"); // 实例化User对象
  2. $condition[‘name‘] = ‘thinkphp‘;
  3. $condition[‘status‘] = 1;
  4. // 把查询条件传入查询方法
  5. $User->where($condition)->select();

最后生成的SQL语句是

  1. SELECT * FROM think_user WHERE `name`=‘thinkphp‘ AND status=1

如果进行多字段查询,那么字段之间的默认逻辑关系是 逻辑与 AND,但是用下面的规则可以更改默认的逻辑判断,通过使用 _logic 定义查询逻辑:

  1. $User = M("User"); // 实例化User对象
  2. $condition[‘name‘] = ‘thinkphp‘;
  3. $condition[‘account‘] = ‘thinkphp‘;
  4. $condition[‘_logic‘] = ‘OR‘;
  5. // 把查询条件传入查询方法
  6. $User->where($condition)->select();

最后生成的SQL语句是

  1. SELECT * FROM think_user WHERE `name`=‘thinkphp‘ OR `account`=‘thinkphp‘
三、使用对象方式来查询

这里以stdClass内置对象为例:

  1. $User = M("User"); // 实例化User对象
  2. // 定义查询条件
  3. $condition = new stdClass();
  4. $condition->name = ‘thinkphp‘;
  5. $condition->status= 1;
  6. $User->where($condition)->select();

最后生成的SQL语句和上面一样

  1. SELECT * FROM think_user WHERE `name`=‘thinkphp‘ AND status=1

使用对象方式查询和使用数组查询的效果是相同的,并且是可以互换的,大多数情况下,我们建议采用数组方式更加高效。

使用数组和对象方式查询的时候,如果传入了不存在的查询字段是会被自动过滤的,例如:

  1. $User = M("User"); // 实例化User对象
  2. $condition[‘name‘] = ‘thinkphp‘;
  3. $condition[‘status‘] = 1;
  4. $condition[‘test‘] = ‘test‘;
  5. // 把查询条件传入查询方法
  6. $User->where($condition)->select();

因为数据库的test字段是不存在的,所以系统会自动检测并过滤掉$condition[‘test‘] = ‘test‘这一查询条件。

如果是3.2.2版本以上,当开启调试模式的话,则会抛出异常,显示:错误的查询条件

原文地址:https://www.cnblogs.com/furuihua/p/11811070.html

时间: 2024-08-14 04:22:23

ThinkPHP可以支持直接使用字符串作为查询条件的相关文章

工作总结篇:mysql使用字符串作为查询条件

前言:今天在做mysql的查询时遇到一个问题,情景是这样的,假如现在我的一张表里面有一个字段scode(表示商品编号),然后有一个字符串存储了多个商品编号,如"0001ME,0002BL"是一个字符串,假如叫str,本来是打算使用in的方式,就是说想把str作为in的条件,如下where scode in "0001ME,0002BL",但是没有成功,然后就查阅mysql的文档,找各种函数,最后发现了instr这个函数,问题解决了,下面说一下结果过程 1.开始的时候

Thinkphp 查询条件 and 和 or同时使用即复合查询

        thinkphp 3.2快捷查询OR查询&分割表示AND查询讲解         快捷查询方式是一种多字段查询的简化写法,可以进一步简化查询条件的写法,在多个字段之间用|分割表示OR查询,用&分割表示AND查询,可以实现下面的查询,例如:         一.不同字段相同的查询条件 $User = M("User"); // 实例化User对象             $map['name|title'] = 'thinkphp';           

thinkphp 同一字段不同查询条件实现

搞定了 另外区间查询还可以支持更多的条件,只要是针对一个字段的条件都可以写到一起,例如:$map['name'] = array(array('like','%a%'), array('like','%b%'), array('like','%c%'), 'ThinkPHP','or'); 最后的查询条件是:(`name` LIKE '%a%') OR (`name` LIKE '%b%') OR (`name` LIKE '%c%') OR (`name` = 'ThinkPHP')

让Asp.net mvc WebAPI 支持OData协议进行分页查询操作

这是我在用Asp.net mvc WebAPI 支持 OData协议 做分页查询服务时的 个人拙笔. 代码已经开发到oschina上.有兴趣的朋友可以看看,欢迎大家指出不足之处. 看过了园子里的几篇关于ASP.NET MVC WebAPI 支持OData协议的文章,很受启发. 但是对于OData协议下对数据的分页查询,确实没有找到让我满意的东西,可能是个人就这脾气.不喜欢复杂. 对于在 WebAPI 支持OData协议,好处不多讲了,反正,我个人是非常乐意用它来做服务接口之类的. 这篇笔记的主题

thinkphp分页时保持查询条件

thinkphp 查询数据时需要分页显示时,会出现只有第1页是按查询条件查到的数据,而其他页面都恢复了,我们想要的结果却是:在翻页时,查询条件保持不变. 原因是:在分页跳转的时候,没有将查询条件作为分页参数传递到下一页.原来翻页的时候,存储在REQUEST变量中的参数并未被传递到下一页,因为表单的 method = “post”,而点击进入下一页时,很明显form表单被重置了,所以打印REQUEST变量也是空的. thinkphp RBAC的示例代码中给出了: PHP $p = new Page

MVC+Bootstrap+Drapper使用PagedList.Mvc支持多查询条件分页

前几天做一个小小小项目,使用了MVC+Bootstrap,以前做分页都是异步加载Mvc部分视图的方式,因为这个是小项目,就随便一点.一般的列表页面,少不了有查询条件,下面分享下Drapper+PagedList.Mvc支持多查询条件分页的使用经验. 在MVC中我们一般习惯使用强类型Model,通过分析Orders的展示页面,来构建这个Model. 1.查询参数的Model public class OrderQueryParamModel { /// <summary> /// 订单编号 //

支持城市及查询条件 车行易查违章接口代码示例

车行易查违章接口可以查询支持城市及查询条件,并且查询违章,违章列表.违章时间.违章地点.违章行为.违章代码.违章扣分.违章罚款等等. 注意:目前大部分省份的交警系统数据已全省联网,指定一个省份下的任何一个地市,均可得到相同数据 接口名称:车行易查违章接口 接口平台:聚合数据 接口地址:http://v.juhe.cn/wzcxy/query 支持格式:JSON 请求方式:HTTP GET/POST 请求示例:http://v.juhe.cn/wzcxy/query?key=您申请的APPKEY&

SAP ABAP编程 在string类型A字符串中查询匹配string类型B字符串

如题,在string类型A字符串中查询匹配string类型B字符串,方法如下: DATA: a TYPE string VALUE 'ABCDEFGHIJKLNM', b TYPE string VALUE 'EFGHIJ', c TYPE string . DATA: off  TYPE i VALUE 0,   "从自己个字符开始查找 moff TYPE i, mlen TYPE i. FIND b IN SECTION OFFSET off OF a MATCH OFFSET moff &

字符串操作--查询字符串出现的次数

1.获取一个字符串在另一个字符串中出现的次数 思路: 1,定义个计数器. 2,获取kk第一次出现的位置. 3,从第一次出现位置后剩余的字符串中继续获取kk出现的位置. 每获取一次就计数一次. 4,当获取不到时,计数完成 程序示例: package tan; public class StringTest2 { public static void sop(String str) { System.out.println(str); } // 缺陷:每次截取字符串占用了很多内存空间 public