drupal7中基本的数据库操作实例详解
drupal是用数据库来存网站内容的,不像静态页那样直接是html文件,Drupal 7 数据库API增加了一些新的功能让语法更加清晰,使用也更加方便。它还能使用查询生成器来构造查询对象的能力,无需在代码中写原始的SQL语句,一是提高了代码可阅读性,二是兼容所有数据库。下面就列罗出一些经常使用的技巧,可能不够全面,还请大家多多补充。
1. 单表查询(最基本使用方法)
<span style="margin:0px; padding:0px; color:rgb(0,0,0)"><span style="margin:0px; padding:0px; color:rgb(0,0,187)"><?php<br/>$result </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">= </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">db_select</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'contact'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">, </span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'c'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">) </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//选择表contact,名一个别名c<br/></span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">fields</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'c'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">) </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//查询c表中的字段,后面不跟参数就是查询所有<br></span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">execute</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">() </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//执行操作<br></span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">fetchAssoc</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//处理结果集<br></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">?></span></span>
2. 条件查询(condition)
<span style="margin:0px; padding:0px; color:rgb(0,0,0)"><span style="margin:0px; padding:0px; color:rgb(0,0,187)"><?php<br/> $result </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">= </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">db_select</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'node'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">, </span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'n'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">)<br/> -></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">fields</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'n'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">)<br> -></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">condition</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'nid'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">, </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">5</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'='</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">) </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//nid等于5的条件<br> </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">condition</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'status'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">, </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">0</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'>'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">) </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//
状态大于0,也就是为真等于1<br> </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">condition</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'uid'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,
array(</span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">1</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">5</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">7</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">),</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'IN'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">) </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//使用IN操作,当然还可以使用
NOT IN<br> </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">execute</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">()<br> -></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">fetchAssoc</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">();<br></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">?></span></span>
3. 联合查询(Join)
<span style="margin:0px; padding:0px; color:rgb(0,0,0)"><span style="margin:0px; padding:0px; color:rgb(0,0,187)"><?php<br/>$query </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">= </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">db_select</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'field_data_field_slide'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'f'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//主表<br/><br/></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">join</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'node'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">, </span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'n'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">, </span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'fa.entity_id
= n.nid'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">// 联合node表,条件是nid<br><br></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">condition</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'f.field_slide_channel_tid'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$chanid</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'='</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">);<br><br></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">condition</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'n.status'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'1'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'='</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//发布状态<br><br></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">fields</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'n'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,array(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'nid'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">)); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//查询nid<br><br></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">orderBy</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'n.nid'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'DESC'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//排序条件<br><br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">range</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">0</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">4</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//取得4条数据<br><br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$result </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">= </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">execute</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">();<br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">?></span></span>
4.添加字段(addField)
<span style="margin:0px; padding:0px; color:rgb(0,0,0)"><span style="margin:0px; padding:0px; color:rgb(0,0,187)"><?php<br/> $query </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">= </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">db_select</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'taxonomy_term_hierarchy'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'h'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//选择表<br/> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">join</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'taxonomy_term_data'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'d'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'h.tid
= d.tid'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">// 联合查询<br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">addField</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'d'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">, </span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'tid'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//
添加字段<br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">condition</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'h.parent'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">0</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//
添加条件where <br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">condition</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'d.vid'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$vid</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//
再添加一个条件 and ....<br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">addTag</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'ditusearch_generate_path'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//
添加Tag 可选项,这个就是方便其他地方可以改变这 个查询$query 比如如果添加了tag 可以使用 hook_query_alter 对其进行查询 如果你使用过views开发,views 也可以了类似的hook<br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$tid </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">= </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">execute</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">()-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">fetchCol</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">();<br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">?></span></span>
5.分页使用(pager)
<span style="margin:0px; padding:0px; color:rgb(0,0,0)"><span style="margin:0px; padding:0px; color:rgb(0,0,187)"><?php<br/> $query </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">= </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">db_select</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'node'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">, </span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'n'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">)<br/> -></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">condition</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'type'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">, </span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'article'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">)<br> -></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">fields</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'n'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">);<br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">= </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">extend</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'PagerDefault'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">)-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">limit</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">2</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//limit条件是分页数目<br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$result </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">= </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">execute</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">();<br> foreach(</span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$result </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">as </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$res</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">){<br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$output </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">.= </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$res</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">title</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">;<br> }<br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$output </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">.= </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">theme</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">‘pager’</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//添加分页theme<br> </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">Return </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$output</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">; <br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">?></span></span>
6.多表联合分页
<span style="margin:0px; padding:0px; color:rgb(0,0,0)"><span style="margin:0px; padding:0px; color:rgb(0,0,187)"><?php<br/> $query </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">= </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">db_select</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'field_data_field_news'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'fa'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">)-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">extend</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'PagerDefault'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); </span><span style="margin:0px; padding:0px; color:rgb(255,128,0)">//多表联合查询extend条件必须放在db_select之后<br><br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">join</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'node'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'n'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'fa.entity_id
= n.nid'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">);<br><br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">join</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'field_data_field_news_date_sort'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">, </span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'fb'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">, </span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'fa.entity_id
= fb.entity_id'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">);<br><br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">fields</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'n'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,
array(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'nid'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'title'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">));<br><br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">condition</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'fa.field_news_classify_tid'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$tids</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'in'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); <br><br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">condition</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'n.type'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'news'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'='</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); <br><br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">condition</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'n.status'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'1'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'='</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">); <br><br></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">orderBy</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'fb.field_news_date_sort_value'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">,</span><span style="margin:0px; padding:0px; color:rgb(221,0,0)">'DESC'</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">);<br><br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">limit</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">(</span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">14</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">);<br><br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$result </span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">= </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">$query</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">-></span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">execute</span><span style="margin:0px; padding:0px; color:rgb(0,119,0)">();<br> </span><span style="margin:0px; padding:0px; color:rgb(0,0,187)">?></span></span>
<span style="margin:0px; padding:0px; color:rgb(0,0,0)"><span style="margin:0px; padding:0px; color:rgb(0,0,187)"><br></span></span>
<span style="margin:0px; padding:0px; color:rgb(0,0,0)"><span style="margin:0px; padding:0px; color:rgb(0,0,187)"><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">function </span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">_module_name_autocomplete</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">(</span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">$string</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">)
{<br> </span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">$matches </span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">= array();<br> <br> </span><span style="font-family:monospace; font-size:14px; color:rgb(255,128,0)">// Some fantasy DB table which holds cities<br> </span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">$query </span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">= </span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">db_select</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">(</span><span style="font-family:monospace; font-size:14px; color:rgb(221,0,0)">'cities'</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">, </span><span style="font-family:monospace; font-size:14px; color:rgb(221,0,0)">'c'</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">);<br> </span><span style="font-family:monospace; font-size:14px; color:rgb(255,128,0)">// Select rows that match the string<br> </span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">$return </span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">= </span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">$query<br> </span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">-></span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">fields</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">(</span><span style="font-family:monospace; font-size:14px; color:rgb(221,0,0)">'c'</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">,
array(</span><span style="font-family:monospace; font-size:14px; color:rgb(221,0,0)">'city'</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">))<br> -></span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">condition</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">(</span><span style="font-family:monospace; font-size:14px; color:rgb(221,0,0)">'c.city'</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">, </span><span style="font-family:monospace; font-size:14px; color:rgb(221,0,0)">'%' </span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">. </span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">db_like</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">(</span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">$string</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">)
. </span><span style="font-family:monospace; font-size:14px; color:rgb(221,0,0)">'%'</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">, </span><span style="font-family:monospace; font-size:14px; color:rgb(221,0,0)">'LIKE'</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">)<br> -></span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">range</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">(</span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">0</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">, </span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">10</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">)<br> -></span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">execute</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">();<br> <br> </span><span style="font-family:monospace; font-size:14px; color:rgb(255,128,0)">// add matches to $matches <br> </span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">foreach (</span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">$return </span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">as </span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">$row</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">)
{<br> </span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">$matches</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">[</span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">$row</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">-></span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">city</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">]
= </span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">check_plain</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">(</span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">$row</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">-></span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">city</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">);<br> }<br> <br> </span><span style="font-family:monospace; font-size:14px; color:rgb(255,128,0)">// return for JS<br> </span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">drupal_json_output</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">(</span><span style="font-family:monospace; font-size:14px; color:rgb(0,0,187)">$matches</span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">); </span><span style="font-family:monospace; font-size:14px; color:rgb(255,128,0)">//--json格式返回<br></span><span style="font-family:monospace; font-size:14px; color:rgb(0,119,0)">}</span></span></span>

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

PHP is a very popular programming language, and CodeIgniter4 is a commonly used PHP framework. When developing web applications, using frameworks is very helpful. It can speed up the development process, improve code quality, and reduce maintenance costs. This article will introduce how to use the CodeIgniter4 framework. Installing the CodeIgniter4 framework The CodeIgniter4 framework can be downloaded from the official website (https://codeigniter.com/). Down

Pagoda Panel is a powerful panel software that can help us quickly deploy, manage and monitor servers, especially small businesses or individual users who often need to build websites, database management and server maintenance. Among these tasks, MySQL database management is an important job in many cases. So how to use the Pagoda panel for MySQL management? Next, we will introduce it step by step. Step 1: Install Pagoda Panel. Before starting to use Pagoda Panel for MySQL management, you first need to install Pagoda Panel.

How to use PHP to perform database operations in a Linux environment. In modern web applications, the database is an essential component. PHP is a popular server-side scripting language that can interact with various databases. This article will introduce how to use PHP scripts for database operations in a Linux environment and provide some specific code examples. Step 1: Install the Necessary Software and Dependencies Before starting, we need to ensure that PHP and related dependencies are installed in the Linux environment. usually

How to use thinkorm to improve database operation efficiency With the rapid development of the Internet, more and more applications require a large number of database operations. In this process, the efficiency of database operations becomes particularly important. In order to improve the efficiency of database operations, we can use thinkorm, a powerful ORM framework, to perform database operations. This article will introduce how to use thinkorm to improve the efficiency of database operations and illustrate it through code examples. 1. What is thinkormthi?

Using PDO for database operations: A better way with PHP In web development, it is very common to use databases for data storage, management, and query. As a language widely used in Web development, PHP naturally provides a wealth of database operation methods. In PHP, you can use MySQLi, PDO and other extension libraries to perform database operations. Among them, PDO is a very commonly used database operation method and has more advantages than other methods. This article will introduce what PDO is to

How to use the FULLOUTERJOIN function in MySQL to obtain the union of two tables. In MySQL, the FULLOUTERJOIN function is a powerful join operation that combines inner joins and outer joins. It can be used to get the union of two tables, that is, combine all the data in the two tables into a single result set. This article will introduce the usage of the FULLOUTERJOIN function and provide some sample code to help readers better understand. FULLOUTERJOIN function

How to use DoctrineORM in Symfony framework for database operations Introduction: Symfony framework is a popular PHP framework that provides many powerful tools and components for building web applications quickly and easily. One of the key components is DoctrineORM, which provides an elegant way to handle database operations. This article will introduce in detail how to use DoctrineORM to perform database operations in the Symfony framework. we will

When developing a website, application or system, database operations and data interaction are essential. As a commonly used backend development language, PHP's database operation and data interaction capabilities are also very powerful. This article will introduce some commonly used database operation functions and data interaction practices in PHP. At the same time, we will explain these operations and practices with code examples to facilitate readers to better understand and apply them. 1. Database connection Before performing database operations, you first need to connect to the database. In PHP we can use
