茄子在线看片免费人成视频,午夜福利精品a在线观看,国产高清自产拍在线观看,久久综合久久狠狠综合

    <s id="ddbnn"></s>
  • <sub id="ddbnn"><ol id="ddbnn"></ol></sub>

  • <legend id="ddbnn"></legend><s id="ddbnn"></s>

    ThinkPHP中where()使用方法詳解
    來源:易賢網(wǎng) 閱讀:1519 次 日期:2016-08-26 15:01:46
    溫馨提示:易賢網(wǎng)小編為您整理了“ThinkPHP中where()使用方法詳解”,方便廣大網(wǎng)友查閱!

    本文介紹ThinkPHP的where()方法的用法。where方法可以用于對數(shù)據(jù)庫操作的結(jié)果進行篩選。即SQL查詢語句中的where子句。

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

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

    字符串條件

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

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

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

    最后生成的SQL語句是

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

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

    $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地址的話,如果傳入的是非數(shù)字類型,則會強制格式化為數(shù)字格式后進行查詢操作。

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

    數(shù)組條件

    數(shù)組條件的where用法是ThinkPHP推薦的用法。

    普通查詢

    最簡單的數(shù)組查詢方式如下:

    $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 (不在)區(qū)間查詢

    [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參數(shù)的話,某些字段也會自動進行模糊查詢。例如設(shè)置了:

    'DB_LIKE_FIELDS'=>'title|content'

    的話,使用

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

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

    支持數(shù)組方式,例如

    $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, 查詢條件支持字符串或者數(shù)組,例如:

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

    和下面的等效:

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

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

    [NOT] IN: 同sql的[not] in ,查詢條件支持字符串或者數(shù)組,例如:

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

    和下面的等效:

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

    查詢條件就變成 id NOT IN (1,5, 8)

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

    例如:

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

    可以改成:

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

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

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

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

    // 要修改的數(shù)據(jù)對象屬性賦值

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

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

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

    快捷查詢

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

    一、實現(xiàn)不同字段相同的查詢條件

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

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

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

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

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

    二、實現(xiàn)不同字段不同的查詢條件

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

    $map['status&title'] =array('1','thinkphp','_multi'=>true);

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

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

    '_multi'=>true必須加在數(shù)組的最后,表示當前是多條件匹配,這樣查詢條件就變成 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'

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

    區(qū)間查詢

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

    $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運算。

    區(qū)間查詢的條件可以支持普通查詢的所有表達式,也就是說類似LIKE、GT和EXP這樣的表達式都可以支持。另外區(qū)間查詢還可以支持更多的條件,只要是針對一個字段的條件都可以寫到一起,例如:

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

    組合查詢

    組合查詢用于復(fù)雜的查詢條件,如果你需要在查詢的時候同時偶爾使用字符串卻又不希望丟失數(shù)組方式的靈活的話,可以考慮使用組合查詢。

    組合查詢的主體還是采用數(shù)組方式查詢,只是加入了一些特殊的查詢支持,包括字符串模式查詢(_string)、復(fù)合查詢(_complex)、請求字符串查詢(_query),混合查詢中的特殊查詢每次查詢只能定義一個,由于采用數(shù)組的索引方式,索引相同的特殊查詢會被覆蓋。

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

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

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

    三、復(fù)合查詢

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

    例如:

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

    復(fù)合查詢使用了_complex作為子查詢條件來定義,配合之前的查詢方式,可以非常靈活的制定更加復(fù)雜的查詢條件。

    很多查詢方式可以相互轉(zhuǎn)換,例如上面的查詢條件可以改成:

    $where['id'] = array('gt',1);

    $where['_string'] = ' (name like "%thinkphp%") OR ( title like "%thinkphp") ';

    最后生成的SQL語句是一致的。

    多次調(diào)用

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

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

    $where['b'] = 1;

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

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

    關(guān)于ThinkPHP中where()方法的使用,本文就介紹這么多,希望對您有所幫助

    更多信息請查看網(wǎng)絡(luò)編程
    易賢網(wǎng)手機網(wǎng)站地址:ThinkPHP中where()使用方法詳解

    2026國考·省考課程試聽報名

    • 報班類型
    • 姓名
    • 手機號
    • 驗證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
    工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)