아래 편집기는 thinkphp 쿼리, 3.X 5.0 방법을 제공합니다(직접 시도해 볼 수 있음). 편집자님이 꽤 좋다고 생각하셔서 지금 공유하고 모두에게 참고용으로 드리고자 합니다. 에디터를 따라가며 함께 살펴볼까요
1. 소개
ThinkPHP에는 데이터 쿼리 작업을 빠르게 수행할 수 있는 매우 유연한 쿼리 메서드가 내장되어 있어 읽기, 업데이트 등의 작업에 쿼리 조건을 사용할 수 있습니다. , 삭제 등은 주로 where 메소드와 같은 일관된 작업을 포함합니다. 어떤 데이터베이스를 사용하든 거의 동일한 쿼리 방법을 사용하며(Mongo와 같은 일부 데이터베이스는 서로 다른 표현식 쿼리를 사용함) 시스템이 차이점을 해결하는 데 도움이 됩니다. 따라서 우리는 프레임워크의 이 쿼리 방법을 쿼리 언어라고 부릅니다. 쿼리 언어는 ThinkPHP 프레임워크의 ORM 하이라이트이기도 하며 쿼리 작업을 더 간단하고 이해하기 쉽게 만듭니다. 쿼리 언어의 의미를 하나씩 설명하겠습니다.
2. 쿼리 방법
ThinkPHP에서는 쿼리 조건으로 문자열을 직접 사용하는 것을 지원할 수 있지만, 대부분의 경우 인덱스 배열이나 객체를 쿼리 조건으로 사용하는 것이 더 안전하기 때문에 권장됩니다.
1. 문자열을 쿼리 조건으로 사용
이것은 가장 전통적인 방법이지만 매우 안전하지 않습니다. 예:
<?php $User = M("User"); // 实例化User对象 $User->where('type=1 AND status=1')->select(); ?>
마지막으로 생성된 SQL 문은
SELECT * FROM think_user WHERE type=입니다. 1 AND status=1
문자열 쿼리를 사용할 때 새 버전에서 제공하는 문자열 조건의 보안 전처리 메커니즘을 사용할 수 있는데 이에 대해서는 당분간 자세히 설명하지 않겠습니다.
2. 쿼리 조건으로 배열 사용
이 방법은 가장 일반적으로 사용되는 쿼리 방법입니다. 예:
<?php $User = M("User"); // 实例化User对象 $condition['name'] = 'thinkphp'; $condition['status'] = 1; // 把查询条件传入查询方法 $User->where($condition)->select(); ?>
최종 생성된 SQL 문은
SELECT * FROM think_user WHERE `name`='thinkphp입니다. ' AND 상태=1
다중 필드 쿼리를 수행하는 경우 필드 간의 기본 논리적 관계는 논리적 AND이지만 _logic을 사용하여 쿼리 논리를 정의함으로써 다음 규칙을 사용하여 기본 논리적 판단을 변경할 수 있습니다.
<?php $User = M("User"); // 实例化User对象 $condition['name'] = 'thinkphp'; $condition['account'] = 'thinkphp'; $condition['_logic'] = 'OR'; // 把查询条件传入查询方法 $User->where($condition)->select(); ?>
최종적으로 생성된 SQL 문은
SELECT * FROM think_user WHERE `name`='thinkphp' OR `account`='thinkphp'
3입니다. 개체 메서드를 사용하여
여기에 stdClass가 있습니다. 내장 객체 예:
<?php $User = M("User"); // 实例化User对象 // 定义查询条件 $condition = new stdClass(); $condition->name = 'thinkphp'; $condition->status= 1; $User->where($condition)->select(); ?>
최종 생성된 SQL 문은 위와 동일합니다
SELECT * FROM think_user WHERE `name`='thinkphp' AND status=1
객체 모드 쿼리를 사용하고 다음을 사용하는 효과 배열 쿼리는 동일하며 상호 교환이 가능합니다. 대부분의 경우 더 효율적으로 배열 방법을 사용하는 것이 좋습니다.
3. 표현식 쿼리
위 쿼리 조건은 단순한 동등 판단에 불과하며, 더 많은 SQL 쿼리 구문을 지원하기 위해 쿼리 표현식을 사용할 수 있으며, 이는 ThinkPHP 쿼리 언어의 핵심이기도 합니다. 사용 형식: $map['필드 이름'] = array('표현식','쿼리 조건');
표현식은 대소문자를 구분하지 않습니다. 지원되는 쿼리 표현식은 다음과 같으며 각각의 의미는 다음과 같습니다. EQ는 다음과 같습니다(=)
NEQ는 다음과 같지 않습니다(a8093152e673feb7aba1828c43532094)GT는 다음보다 큼(>)
EGT는 다음과 같거나 같습니다(>=)LT는 다음보다 작습니다(<)
ELT는 다음보다 작거나 같음(<=)
LIKE 퍼지 쿼리
[NOT] BETWEEN(아님) 간격 쿼리
[NOT] IN(아님) IN 쿼리
EXP 표현식 쿼리, SQL 구문 지원
예
1.EQ: 같음 (=)
예: $map['id'] = array('eq',100); ['id'] = 100; id = 100
2.NEQ: (a8093152e673feb7aba1828c43532094)과 같지 않음예: $map['id'] = array('neq ',100); 표시된 쿼리 조건은 id a8093152e673feb7aba1828c43532094 100
3.GT: 보다 큼(>)예: $map['id'] = array('gt',100 ); 표시된 쿼리 조건은 id > 100
4.EGT: 크거나 같음 ( >=)예: $map['id'] = array('egt',100) ; 표시된 쿼리 조건은 id >= 100
5.LT: Less than (67a5e8be9a88ac9090cb532f8bd80a6d'title|content'가 설정된 경우 $map['title'] = 'thinkphp'를 사용하면 쿼리 조건은 '%thinkphp%'배열 모드를 지원합니다. :
例如 $map['a'] =array('like',array('%thinkphp%','%tp'),'OR'); $map['b']=array('notlike',array('%thinkphp%','%tp'),'AND');
生成的查询条件就是:
(a like '%thinkphp%' OR a like '%tp') AND (b not like '%thinkphp%' AND b not like '%tp')
8.[NOT] BETWEEN :同sql的[not] between, 查询条件支持字符串或者数组,
例如: $map['id'] = array('between','1,8');和下面的等效: $map['id'] = array('between',array('1','8'));
查询条件就变成 id BETWEEN 1 AND 8
9.[NOT] IN: 同sql的[not] in ,查询条件支持字符串或者数组,
例如: $map['id'] = array('not in','1,5,8');和下面的等效: $map['id'] = array('not in',array('1','5','8'));
查询条件就变成 id NOT IN (1,5, 8)
10.EXP:表达式,支持更复杂的查询情况
例如:$map['id'] = array('in','1,3,8');可以改成: $map['id'] = array('exp',' IN (1,3,8) ');
exp查询的条件不会被当成字符串,所以后面的查询条件可以使用任何SQL支持的语法,包括使用函数和字段名称。查询表达式不仅可用于查询条件,也可以用于数据更新,例如:
<?php $User = M("User"); // 实例化User对象 // 要修改的数据对象属性赋值 $data['name'] = 'ThinkPHP'; $data['score'] = array('exp','score+1');// 用户的积分加1 $User->where('id=5')->save($data); // 根据条件保存修改的数据 ?>
四、快捷查询
从3.0版本开始,增加了快捷查询方式,可以进一步简化查询条件的写法,例如:
1.实现不同字段相同的查询条件
<?php $User = M("User"); // 实例化User对象 $map['name|title'] = 'thinkphp'; // 把查询条件传入查询方法 $User->where($map)->select(); ?>
查询条件就变成
name= 'thinkphp' OR title = 'thinkphp'
2.实现不同字段不同的查询条件
<?php $User = M("User"); // 实例化User对象 $map['status&title'] =array('1','thinkphp','_multi'=>true); // 把查询条件传入查询方法 $User->where($map)->select(); ?>
'_multi'=>true必须加在数组的最后,表示当前是多条件匹配,这样查询条件就变成 status= 1 AND title = 'thinkphp',
查询字段支持更多的,例如:
$map['status&score&title'] =array('1',array('gt','0'),'thinkphp','_multi'=>true);
查询条件就变成
status= 1 AND score >0 AND title = 'thinkphp'
注意:快捷查询方式中“|”和“&”不能同时使用。
五、区间查询
ThinkPHP支持对某个字段的区间查询,
例如: $map['id'] = array(array('gt',1),array('lt',10)) ;
得到的查询条件是: (`id` > 1) AND (`id` 13e6bb2942fd9623f93f45b2b42d7d12 3) OR (`id` 3a5daf68982d23e74067037833b54044 3)
最后一个可以是AND、 OR或者 XOR运算符,如果不写,默认是AND运算。
区间查询的条件可以支持普通查询的所有表达式,也就是说类似LIKE、GT和EXP这样的表达式都可以支持。另外区间查询还可以支持更多的条件,只要是针对一个字段的条件都可以写到一起,例如:
$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')
六、组合查询
组合查询的主体还是采用数组方式查询,只是加入了一些特殊的查询支持,包括字符串模式查询(_string)、复合查询(_complex)、请求字符串查询(_query),混合查询中的特殊查询每次查询只能定义一个,由于采用数组的索引方式,索引相同的特殊查询会被覆盖。
1.字符串模式查询(采用_string 作为查询条件)
数组条件还可以和字符串条件混合使用,例如:
<?php $User = M("User"); // 实例化User对象 $map['id'] = array('neq',1); $map['name'] = 'ok'; $map['_string'] = 'status=1 AND score>10'; $User->where($map)->select(); ?>
最后得到的查询条件就成了:
( `id` != 1 ) AND ( `name` = 'ok' ) AND ( status=1 AND score>10 )
2.请求字符串查询方式
请求字符串查询是一种类似于URL传参的方式,可以支持简单的条件相等判断。
<?php $map['id'] = array('gt','100'); $map['_query'] = 'status=1&score=100&_logic=or'; ?>
得到的查询条件是:
`id`>100 AND (`status` = '1' OR `score` = '100')
七、复合查询
复合查询相当于封装了一个新的查询条件,然后并入原来的查询条件之中,所以可以完成比较复杂的查询条件组装。
例如:
<?php $where['name'] = array('like', '%thinkphp%'); $where['title'] = array('like','%thinkphp%'); $where['_logic'] = 'or'; $map['_complex'] = $where; $map['id'] = array('gt',1); ?>
查询条件是
( id > 1) AND ( ( name like '%thinkphp%') OR ( title like '%thinkphp%') )
复合查询使用了_complex作为子查询条件来定义,配合之前的查询方式,可以非常灵活的制定更加复杂的查询条件。
很多查询方式可以相互转换,例如上面的查询条件可以改成:
$where['id'] = array('gt',1);
$where['_string'] = ' (name like "%thinkphp%") OR ( title like "%thinkphp") ';
最后生成的SQL语句是一致的。
八、统计查询
在应用中我们经常会用到一些统计数据,例如当前所有(或者满足某些条件)的用户数、所有用户的最大积分、用户的平均成绩等等,ThinkPHP为这些统计操作提供了一系列的内置方法,包括:
Count 统计数量,参数是要统计的字段名(可选)
Max 获取最大值,参数是要统计的字段名(必须)
Min 获取最小值,参数是要统计的字段名(必须)
Avg 获取平均值,参数是要统计的字段名(必须)
Sum 获取总分,参数是要统计的字段名(必须)
用法示例:
$User = M("User"); // 实例化User对象
获取用户数: $userCount = $User->count();
或者根据字段统计: $userCount = $User->count("id");
获取用户的最大积分: $maxScore = $User->max('score');
获取积分大于0的用户的最小积分: $minScore = $User->where('score>0')->min('score');
获取用户的平均积分: $avgScore = $User->avg('score');
统计用户的总成绩: $sumScore = $User->sum('score');
并且所有的统计查询均支持连贯操作的使用。
九、SQL查询
ThinkPHP内置的ORM和ActiveRecord模式实现了方便的数据存取操作,而且新版增加的连贯操作功能更是让这个数据操作更加清晰,但是ThinkPHP仍然保留了原生的SQL查询和执行操作支持,为了满足复杂查询的需要和一些特殊的数据操作,SQL查询的返回值因为是直接返回的Db类的查询结果,没有做任何的处理。主要包括下面两个方法:
1.query方法 :执行SQL查询操作
用法 query($sql,$parse=false)
参数 sql(必须):要查询的SQL语句
parse(可选):是否需要解析SQL
返回值 如果数据非法或者查询错误则返回false
否则返回查询结果数据集(同select方法)
使用示例:
<?php $Model = new Model() // 实例化一个model对象 没有对应任何数据表 $Model->query("select * from think_user where status=1"); ?>
如果你当前采用了分布式数据库,并且设置了读写分离的话,query方法始终是在读服务器执行,因此query方法对应的都是读操作,而不管你的SQL语句是什么。
2.execute方法 :execute用于更新和写入数据的sql操作
用法 execute($sql,$parse=false)
参数 sql(必须):要执行的SQL语句
parse(可选):是否需要解析SQL
返回值 如果数据非法或者查询错误则返回false 否则返回影响的记录数
使用示例:
<?php $Model = new Model() // 实例化一个model对象 没有对应任何数据表 $Model->execute("update think_user set name='thinkPHP' where status=1"); ?>
如果你当前采用了分布式数据库,并且设置了读写分离的话,execute方法始终是在写服务器执行,因此execute方法对应的都是写操作,而不管你的SQL语句是什么。
十、动态查询
借助PHP5语言的特性,ThinkPHP实现了动态查询,核心模型的动态查询方法包括下面几种:
getBy 根据字段的值查询数据 例如,getByName,getByEmail
getFieldBy 根据字段查询并返回某个字段的值 例如,getFieldByName
1.getBy动态查询:该查询方式针对数据表的字段进行查询记录。
例如,User对象拥有id,name,email,address 等属性,那么我们就可以使用下面的查询方法来直接根据某个属性来查询符合条件的记录。
<?php $user = $User->getByName('liu21st'); $user = $User->getByEmail('liu21st@gmail.com'); $user = $User->getByAddress('中国深圳'); ?>
暂时不支持多数据字段的动态查询方法,请使用find方法和select方法进行查询。
2.getFieldBy 동적 쿼리: 특정 필드를 쿼리하고 특정 필드의 값을 반환합니다. 예를 들어
$userId = $User->getFieldByName('liu21st','id');
는 기반을 의미합니다. 사용자 이름에서 사용자의 ID 값을 가져옵니다.
11. 하위 쿼리
버전 3.0부터 하위 쿼리 지원이 추가되었습니다.
1 select 메서드를 사용하세요
. false , 쿼리가 수행되지 않고 생성된 SQL만 반환됨을 나타냅니다. 예:
// 먼저 하위 쿼리 SQL을 생성합니다
$subQuery = $model->field('id,name')->table( 'tablename')-> group('field')->where($where)->order('status')->select(false);
select 메소드가 false 매개변수를 전달하면, 이는 현재 쿼리가 실행되지 않고 쿼리 SQL만 생성한다는 의미입니다.
2 buildSql 메소드를 사용하세요
$subQuery = $model->field('id,name')->table('tablename')->group('field')->where ( $where)->order('status')->buildSql();
buildSql 메소드 호출 후 실제 쿼리 연산은 수행되지 않고 해당 쿼리의 SQL문만 생성됩니다. 혼동을 피하기 위해 양쪽의 SQL Add 괄호 안에 있을 것입니다. 그런 다음 후속 쿼리에서 직접 호출합니다.
//하위 쿼리를 사용하여 쿼리
$model->table($subQuery.' a')->where()->order()->select()
구성된 하위 쿼리 SQL을 사용할 수 있습니다. 일관성 테이블 위치 등 ThinkPHP의 작업 방법
위의 thinkphp 쿼리, 3.
위 내용은 thinkphp 쿼리, 3.X 5.0 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!