日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

php根据id查找条件怎么写_thinkphp where()条件查询

發布時間:2023/12/1 php 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php根据id查找条件怎么写_thinkphp where()条件查询 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

今天來給大家講下查詢最常用但也是最復雜的where方法,where方法也屬于模型類的連貫操作方法之一,主要用于查詢和操作條件的設置。

where方法的用法是ThinkPHP查詢語言的精髓,也是ThinkPHP ORM的重要組成部分和亮點所在,可以完成包括普通查詢、表達式查詢、快捷查詢、區間查詢、組合查詢在內的查詢操作。where方法的參數支持字符串和數組,雖然也可以使用對象但并不建議。

字符串條件

使用字符串條件直接查詢和操作,例如:

$User?=M("User");//?實例化User對象

$User->where('type=1?AND?status=1')->select();

最后生成的SQL語句是

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

如果使用3.1以上版本的話,使用字符串條件的時候,建議配合預處理機制,確保更加安全,例如:

$Model->where("id=%d?and?username='%s'?and

xx='%f'",array($id,$username,$xx))->select();

或者使用:

$Model->where("id=%d?and?username='%s'?and?xx='%f'",$id,$username,$xx)->select();

如果$id變量來自用戶提交或者URL地址的話,如果傳入的是非數字類型,則會強制格式化為數字格式后進行查詢操作。

字符串預處理格式類型支持指定數字、字符串等,具體可以參考vsprintf方法的參數說明。

數組條件

數組條件的where用法是ThinkPHP推薦的用法。

普通查詢

最簡單的數組查詢方式如下:

$User?=M("User");//?實例化User對象

$map['name']='thinkphp';

$map['status']=1;

//?把查詢條件傳入查詢方法

$User->where($map)->select();

最后生成的SQL語句是

SELECT?*FROM?think_user?WHERE?`name`='thinkphp'AND?status=1

表達式查詢

上面的查詢條件僅僅是一個簡單的相等判斷,可以使用查詢表達式支持更多的SQL查詢語法,查詢表達式的使用格式:

$map['字段1']=array('表達式','查詢條件1');

$map['字段2']=array('表達式','查詢條件2');

$Model->where($map)->select();//?也支持

表達式不分大小寫,支持的查詢表達式有下面幾種,分別表示的含義是:

表達式

含義

EQ

等于(=)

NEQ

不等于(<>)

GT

大于(>)

EGT

大于等于(>=)

LT

小于(

ELT

小于等于(<=)

LIKE

模糊查詢

[NOT]?BETWEEN

(不在)區間查詢

[NOT]?IN

(不在)IN?查詢

EXP

表達式查詢,支持SQL語法

示例如下:

EQ?:等于(=)

例如:

$map['id']=array('eq',100);

和下面的查詢等效

$map['id']=100;

表示的查詢條件就是 id = 100

NEQ: 不等于(<>)

例如:

$map['id']=array('neq',100);

表示的查詢條件就是 id <> 100

GT:大于(>)

例如:

$map['id']=array('gt',100);

表示的查詢條件就是 id > 100

EGT:大于等于(>=)

例如:

$map['id']=array('egt',100);

表示的查詢條件就是 id >= 100

LT:小于(

例如:

$map['id']=array('lt',100);

表示的查詢條件就是 id < 100

ELT: 小于等于(<=)

例如:

$map['id']=array('elt',100);

表示的查詢條件就是 id <= 100

[NOT] LIKE: 同sql的LIKE

例如:

$map['name']=array('like','thinkphp%');

查詢條件就變成 name like 'thinkphp%'

如果配置了DB_LIKE_FIELDS參數的話,某些字段也會自動進行模糊查詢。例如設置了:

'DB_LIKE_FIELDS'=>'title|content'

的話,使用

$map['title']='thinkphp';

查詢條件就會變成 name like '%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')

[NOT] BETWEEN?:同sql的[not] between, 查詢條件支持字符串或者數組,例如:

$map['id']=array('between','1,8');

和下面的等效:

$map['id']=array('between',array('1','8'));

查詢條件就變成 id BETWEEN 1 AND 8

[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)

EXP:表達式,支持更復雜的查詢情況

例如:

$map['id']=array('in','1,3,8');

可以改成:

$map['id']=array('exp','?IN?(1,3,8)?');

exp查詢的條件不會被當成字符串,所以后面的查詢條件可以使用任何SQL支持的語法,包括使用函數和字段名稱。

查詢表達式不僅可用于查詢條件,也可以用于數據更新,例如:

$User?=M("User");//?實例化User對象

//?要修改的數據對象屬性賦值

$data['name']='ThinkPHP';

$data['score']=array('exp','score+1');//?用戶的積分加1

$User->where('id=5')->save($data);//?根據條件保存修改的數據

快捷查詢

where方法支持快捷查詢方式,可以進一步簡化查詢條件的寫法,例如:

一、實現不同字段相同的查詢條件

$User?=M("User");//?實例化User對象

$map['name|title']='thinkphp';

//?把查詢條件傳入查詢方法

$User->where($map)->select();

查詢條件就變成?name=?'thinkphp' OR title = 'thinkphp'

二、實現不同字段不同的查詢條件

$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'

注意:快捷查詢方式中“|”和“&”不能同時使用。

區間查詢

where方法支持對某個字段的區間查詢,例如:

$map['id']=array(array('gt',1),array('lt',10));

得到的查詢條件是:?(`id` > 1) AND (`id` < 10)

$map['id']=array(array('gt',3),array('lt',10),'or');

得到的查詢條件是: (`id` > 3) OR (`id` < 10)

$map['id']=array(array('neq',6),array('gt',3),'and');

得到的查詢條件是:(`id` != 6) AND (`id` > 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),混合查詢中的特殊查詢每次查詢只能定義一個,由于采用數組的索引方式,索引相同的特殊查詢會被覆蓋。

一、字符串模式查詢(采用_string 作為查詢條件)

數組條件還可以和字符串條件混合使用,例如:

$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 )

二、請求字符串查詢方式

請求字符串查詢是一種類似于URL傳參的方式,可以支持簡單的條件相等判斷。

$map['id']=array('gt','100');

$map['_query']='status=1&score=100&_logic=or';

得到的查詢條件是:`id`>100 AND (`status` = '1' OR `score` = '100')

三、復合查詢

復合查詢相當于封裝了一個新的查詢條件,然后并入原來的查詢條件之中,所以可以完成比較復雜的查詢條件組裝。

例如:

$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語句是一致的。

多次調用

3.1.3版本開始,where方法支持多次調用,但字符串條件只能出現一次,例如:

$map['a']=array('gt',1);

$where['b']=1;

$Model->where($map)->where($where)->where('status=1')->select();

多次的數組條件表達式會最終合并,但字符串條件則只支持一次。

這就是微學網-程序員之家為你提供的"thinkphp where()條件查詢"希望對你有所幫助.本文來自網絡,轉載請注明出處:http://www.weixuecn.cn/article/7432.html

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的php根据id查找条件怎么写_thinkphp where()条件查询的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。