国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

mysql - 如何高效的查詢需要合并大數(shù)據(jù)表的操作

瀏覽:207日期:2022-06-19 13:20:33

問題描述

1.存在兩個(gè)數(shù)據(jù)庫Shanghai和Beijing(假設(shè)其他數(shù)據(jù)丟失,中國人口數(shù)據(jù)只剩下上海和北京)2.兩個(gè)數(shù)據(jù)庫中都有同樣結(jié)構(gòu)的表table_people,數(shù)據(jù)量都在一千萬左右3.有以下數(shù)據(jù)Shanghai.table_people

idusernamebirthday1jhon2016-08-15 12:00:002may2016-08-14 13:00:003abcd11112015-08-01 14:00:00............

Beijing.table_people

idusernamebirthday1mike2016-08-16 23:58:002kitty2016-08-03 15:00:063ab1112014-01-01 15:16:18............

問:1.如何高效的(1s內(nèi))查出最近在中國出生的前十個(gè)人2.對(duì)于YII框架數(shù)據(jù)提供器應(yīng)該怎么寫

問題解答

回答1:

(SELECT * FROM Beijing.table_people ORDER BY birthday limit 10)union all(SELECT * FROM shanghai.table_people ORDER BY birthday limit 10)ORDER BY birthday limit 10

你看這種思路可以嗎?

回答2:

birthday類型得是datetime不能是string,然后作索引。查的時(shí)候先union all再order by再limit 10。mysql內(nèi)部應(yīng)該是就是對(duì)兩個(gè)索引做一下歸并排序

如果想更快,就把birthday類型改成int的

回答3:

每個(gè)表都取符合條件的前10條數(shù)據(jù),然后再對(duì)取出來的數(shù)據(jù)在代碼里排序并取出最終的前10條數(shù)據(jù)。

不過這樣寫代碼也很累,以后加一個(gè)表就得改代碼,所以建議找一下數(shù)據(jù)庫中間件的相關(guān)資料。

回答4:

兩個(gè)sql,根據(jù)id desc 以及l(fā)imit 10,都插入到一個(gè)臨時(shí)表,對(duì)20條數(shù)據(jù)時(shí)間排序再limit10

相關(guān)文章:
主站蜘蛛池模板: 扎囊县| 九江市| 和田市| 泰州市| 吉水县| 延吉市| 明星| 木里| 都匀市| 穆棱市| 肥东县| 呈贡县| 营口市| 天柱县| 榆中县| 漳州市| 阿拉善右旗| 长葛市| 永吉县| 定陶县| 壤塘县| 阿城市| 新河县| 拜泉县| 德化县| 常州市| 清新县| 恩平市| 双牌县| 永善县| 吐鲁番市| 怀宁县| 新宁县| 晋宁县| 襄汾县| 琼中| 福泉市| 康保县| 三都| 花莲市| 丰台区|