欧美亚洲大片-国产免费成人在线视频-国产成人8x人在线视频软件-日韩亚洲欧美中文字幕-97伦伦午夜电影理伦片-亚洲综合精品视频-曰本女人牲交高潮视频-久久久精品欧美-天天干天天操天天碰-精品国产乱码久久久久久1区2区-黄色一级免费片-在线免费欧美-国产成人精品在线视频-精人妻一区二区三区-香蕉视频2020-综合久久99-欧美日韩亚洲国产综合

十年專注于品牌網(wǎng)站建設(shè) 十余年專注于網(wǎng)站建設(shè)_小程序開發(fā)_APP開發(fā),低調(diào)、敢創(chuàng)新、有情懷!
南昌百恒網(wǎng)絡(luò)微信公眾號(hào) 掃一掃關(guān)注
小程序
tel-icon全國(guó)服務(wù)熱線:400-680-9298,0791-88117053
掃一掃關(guān)注百恒網(wǎng)絡(luò)微信公眾號(hào)
掃一掃打開百恒網(wǎng)絡(luò)微信小程序

百恒網(wǎng)絡(luò)

南昌百恒網(wǎng)絡(luò)

數(shù)據(jù)查詢過(guò)程中能不能用in、not in 、exists

百恒網(wǎng)絡(luò) 2014-06-09 6087

在做數(shù)據(jù)庫(kù)查詢過(guò)程中,遇到跨表查詢,即需要用到另一張表的ID來(lái)列出當(dāng)前表的記錄,通常情況我們會(huì)想到跨表查詢,結(jié)合子查詢只要使用一句SQL語(yǔ)就可以解決問(wèn)題,例如:$sql="select * from table1 where Id not in(select QuestionId from table2 where UserName='".$UserName."')",大多數(shù)初級(jí)開發(fā)者都認(rèn)為,用查詢關(guān)鍵肯定是最優(yōu)的實(shí)現(xiàn)方法,所以大都初級(jí)開發(fā)都會(huì)用到in或exists等語(yǔ)句,對(duì)數(shù)據(jù)記錄比較少的兩張表查詢,但沒(méi)有明顯示區(qū)別,但是當(dāng)記錄才達(dá)到幾萬(wàn)條,同時(shí)有十幾個(gè)人訪問(wèn),就會(huì)明顯感覺到延時(shí),所謂的卡機(jī),就是算法執(zhí)行的效率不高出現(xiàn)的原因,針對(duì)這樣的情況,我們建議開發(fā)者盡量避免使用這些關(guān)鍵詞那么用什么方法解決這種問(wèn)題呢?

解決方法是,我們可以用最原始的嵌套循環(huán),第一把子查詢的中的ID一個(gè)個(gè)讀出來(lái),再在table1 中進(jìn)行查詢,這樣執(zhí)行的速度比較快.代碼如下所示:

$sql="select QuestionId from table2 where UserName='".$UserName."'";

$result=$conn->query($sql);

if ($result)

{

while($row = $result->fetch_array())

{

$psql ="select * from table1 where id=".$row['QId'];

$presult = $conn->query($psql);

if ($presult){

$rowp = $presult->fetch_array();

…… }

}

百恒技術(shù)工程師建議大家,若是小型數(shù)據(jù)查詢,使用in,exists是沒(méi)有任何問(wèn)題,盡量縮小雙邊的查詢范圍,以減輕資源的消耗.對(duì)于大型數(shù)據(jù)查詢,盡量不要用.

希望此文章能對(duì)廣開發(fā)者有所幫助,原創(chuàng)文章出自:百恒網(wǎng)絡(luò) 如轉(zhuǎn)載請(qǐng)注明出處!專業(yè),專注于南昌網(wǎng)站建設(shè),為用戶提供高品質(zhì)的網(wǎng)絡(luò)產(chǎn)品及優(yōu)質(zhì)服務(wù)是我們始終的追求.

400-680-9298,0791-88117053
掃一掃關(guān)注百恒網(wǎng)絡(luò)微信公眾號(hào)
掃一掃打開百恒網(wǎng)絡(luò)小程序

歡迎您的光顧,我們將竭誠(chéng)為您服務(wù)×

售前咨詢 售前咨詢
 
售前咨詢 售前咨詢
 
售前咨詢 售前咨詢
 
售前咨詢 售前咨詢
 
售前咨詢 售前咨詢
 
售后服務(wù) 售后服務(wù)
 
售后服務(wù) 售后服務(wù)
 
備案專線 備案專線
 
×
永兴县| 林甸县| 庄河市| 蓬溪县| 新绛县| 云霄县| 新兴县| 伊吾县| 宜丰县| 安化县| 田阳县| 拉萨市| 喀什市| 高阳县| 德惠市| 利辛县| 滁州市| 奉化市| 凤台县| 天台县| 大丰市| 天台县| 密山市| 五大连池市| 井冈山市| 南岸区| 兴业县| 广灵县| 子洲县| 文安县| 宽甸| 伊宁县| 益阳市| 湖南省| 洱源县| 大英县| 商河县| 雷州市| 金溪县| 介休市| 屯昌县|