电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

實例詳解mysql子查詢

瀏覽:4日期:2023-10-11 17:44:25

子查詢分類

按返回結(jié)果集分類

子查詢按返回結(jié)果集的不同分為4種:表子查詢,行子查詢,列子查詢和標量子查詢。 表子查詢:返回的結(jié)果集是一個行的集合,N行N列(N>=1)。表子查詢經(jīng)常用于父查詢的FROM子句中。 行子查詢:返回的結(jié)果集是一個列的集合,一行N列(N>=1)。行子查詢可以用于福查詢的FROM子句和WHERE子句中。 列子查詢:返回的結(jié)果集是一個行的集合,N行一列(N>=1)。 標量子查詢:返回的結(jié)果集是一個標量集合,一行一列,也就是一個標量值??梢灾付ㄒ粋€標量表達式的任何地方,都可以用一個標量子查詢。

從定義上講,每個標量子查詢也是一個行子查詢和一個列子查詢,反之則不是;每個行子查詢和列子查詢也是一個表子查詢,反之也不是。

按照對返回結(jié)果的調(diào)用方法

子查詢按對返回結(jié)果集的調(diào)用方法,可分為where型子查詢,from型子查詢及exists型子查詢。

where型子查詢:(把內(nèi)層查詢結(jié)果當作外層查詢的比較條件)定義:where型的子查詢就是把內(nèi)層查詢的結(jié)果當作外層查詢的條件。 from型子查詢:(把內(nèi)層的查詢結(jié)果供外層再次查詢)定義:from子查詢就是把子查詢的結(jié)果(內(nèi)存里的一張表)當作一張臨時表,然后再對它進行處理。 exists型子查詢:(把外層查詢結(jié)果拿到內(nèi)層,看內(nèi)層的查詢是否成立)定義:exists子查詢就是對外層表進行循環(huán),再對內(nèi)表進行內(nèi)層查詢。和in ()差不多,但是它們還是有區(qū)別的。主要是看兩個張表大小差的程度。若子查詢表大則用exists(內(nèi)層索引),子查詢表小則用in(外層索引);

使用子查詢原則

1.一個子查詢必須放在圓括號中。

2.將子查詢放在比較條件的右邊以增加可讀性。子查詢不包含 ORDER BY 子句。對一個 SELECT 語句只能用一個 ORDER BY 子句,并且如果指定了它就必須放在主 SELECT 語句的最后。

3.在子查詢中可以使用兩種比較條件:單行運算符(>, =, >=, <, <>, <=) 和多行運算符(IN, ANY, ALL)。

實例分析

創(chuàng)建測試表

CREATE TABLE PLAYERS (PLAYERNO INTEGER NOT NULL, NAME CHAR(15) NOT NULL, INITIALS CHAR(3) NOT NULL, BIRTH_DATE DATE , SEX CHAR(1) NOT NULL, JOINED SMALLINT NOT NULL, STREET VARCHAR(30) NOT NULL, HOUSENO CHAR(4) , POSTCODE CHAR(6) , TOWN VARCHAR(30) NOT NULL, PHONENO CHAR(13) , LEAGUENO CHAR(4) , PRIMARY KEY (PLAYERNO)); CREATE TABLE PENALTIES (PAYMENTNO INTEGER NOT NULL, PLAYERNO INTEGER NOT NULL, PAYMENT_DATE DATE NOT NULL, AMOUNT DECIMAL(7,2) NOT NULL, PRIMARY KEY (PAYMENTNO));

注:表players為球員信息基本表,表penalties為有過罰款記錄的球員信息列表。

插入測試數(shù)據(jù)

INSERT INTO PLAYERS VALUES (2, ’Everett’, ’R’, ’1948-09-01’, ’M’, 1975, ’Stoney Road’,’43’, ’3575NH’, ’Stratford’, ’070-237893’, ’2411’);INSERT INTO PLAYERS VALUES (6, ’Parmenter’, ’R’, ’1964-06-25’, ’M’, 1977, ’Haseltine Lane’,’80’, ’1234KK’, ’Stratford’, ’070-476537’, ’8467’);INSERT INTO PLAYERS VALUES (7, ’Wise’, ’GWS’, ’1963-05-11’, ’M’, 1981, ’Edgecombe Way’,’39’, ’9758VB’, ’Stratford’, ’070-347689’, NULL);INSERT INTO PLAYERS VALUES (8, ’Newcastle’, ’B’, ’1962-07-08’, ’F’, 1980, ’Station Road’,’4’, ’6584WO’, ’Inglewood’, ’070-458458’, ’2983’);INSERT INTO PLAYERS VALUES (27, ’Collins’, ’DD’, ’1964-12-28’, ’F’, 1983, ’Long Drive’,’804’, ’8457DK’, ’Eltham’, ’079-234857’, ’2513’);INSERT INTO PLAYERS VALUES (28, ’Collins’, ’C’, ’1963-06-22’, ’F’, 1983, ’Old Main Road’,’10’, ’1294QK’, ’Midhurst’, ’010-659599’, NULL);INSERT INTO PLAYERS VALUES (39, ’Bishop’, ’D’, ’1956-10-29’, ’M’, 1980, ’Eaton Square’,’78’, ’9629CD’, ’Stratford’, ’070-393435’, NULL);INSERT INTO PLAYERS VALUES (44, ’Baker’, ’E’, ’1963-01-09’, ’M’, 1980, ’Lewis Street’,’23’, ’4444LJ’, ’Inglewood’, ’070-368753’, ’1124’);INSERT INTO PLAYERS VALUES (57, ’Brown’, ’M’, ’1971-08-17’, ’M’, 1985, ’Edgecombe Way’,’16’, ’4377CB’, ’Stratford’, ’070-473458’, ’6409’);INSERT INTO PLAYERS VALUES (83, ’Hope’, ’PK’, ’1956-11-11’, ’M’, 1982, ’Magdalene Road’,’16A’, ’1812UP’, ’Stratford’, ’070-353548’, ’1608’);INSERT INTO PLAYERS VALUES (95, ’Miller’, ’P’, ’1963-05-14’, ’M’, 1972, ’High Street’,’33A’, ’5746OP’, ’Douglas’, ’070-867564’, NULL);INSERT INTO PLAYERS VALUES (100, ’Parmenter’, ’P’, ’1963-02-28’, ’M’, 1979, ’Haseltine Lane’,’80’, ’6494SG’, ’Stratford’, ’070-494593’, ’6524’);INSERT INTO PLAYERS VALUES (104, ’Moorman’, ’D’, ’1970-05-10’, ’F’, 1984, ’Stout Street’,’65’, ’9437AO’, ’Eltham’, ’079-987571’, ’7060’);INSERT INTO PLAYERS VALUES (112, ’Bailey’, ’IP’, ’1963-10-01’, ’F’, 1984, ’Vixen Road’,’8’, ’6392LK’, ’Plymouth’, ’010-548745’, ’1319’); INSERT INTO PENALTIES VALUES (1, 6, ’1980-12-08’,100);INSERT INTO PENALTIES VALUES (2, 44, ’1981-05-05’, 75);INSERT INTO PENALTIES VALUES (3, 27, ’1983-09-10’,100);INSERT INTO PENALTIES VALUES (4,104, ’1984-12-08’, 50);INSERT INTO PENALTIES VALUES (5, 44, ’1980-12-08’, 25);INSERT INTO PENALTIES VALUES (6, 8, ’1980-12-08’, 25);INSERT INTO PENALTIES VALUES (7, 44, ’1982-12-30’, 30);INSERT INTO PENALTIES VALUES (8, 27, ’1984-11-12’, 75);

表子查詢實例

如:獲取編號小于10的男性球員的號碼

mysql> select playerno from ( select playerno, sex from players where playerno < 10) as players10 where sex=’M’;

行子查詢實例

如:獲取和100號球員性別相同并且居住在同一城市的球員號碼。

mysql> select playerno from players where (sex, town) = ( select sex, town from players where playerno = 100);

說明:子查詢的結(jié)果是帶有兩個值的一行:(’M’,’stratford’)。這個值和一個行表達式(sex,town)進行比較。

標量子查詢實例

可以指定一個標量表達式的任何地方,幾乎都可以使用一個標量子查詢。 如:獲取和27號球員出生在同一年的球員的號碼

mysql> select playerno from players where year(birth_date) = (select year(birth_date) from players where playerno = 27) and playerno <> 27;

上面語句等同于:

mysql> select playerno from players where year(birth_date) = 1964 and playerno <> 27;

列子查詢實例

由于列子查詢返回的結(jié)果集是 N 行一列,因此不能直接使用 = > < >= <= <> 這些比較標量結(jié)果的操作符。在列子查詢中可以使用 IN、ANY(SOME)和ALL操作符: IN:在指定項內(nèi),同 IN(項1,項2,…)。 ANY:與比較操作符聯(lián)合使用,ANY關(guān)鍵字必須接在一個比較操作符的后面,表示與子查詢返回的任何值比較為 TRUE ,則返回 TRUE 。 SOME:ANY 的別名,較少使用。 ALL:與比較操作符聯(lián)合使用,ALL關(guān)鍵字必須接在一個比較操作符的后面,表示與子查詢返回的所有值比較都為 TRUE ,則返回 TRUE 。

實例1(in):獲取球員性別為女的所有球員的球員號,名字及所在城市。

mysql> select playerno, name, town from players where playerno in (select playerno from players where sex = ’F’);

實例2(any):獲取至少比同城的另一球員年輕的所有球員的號碼,日期和居住城市。

mysql> select playerno, birth_date, town from players as p1 where birth_date > any (select birth_date from players as p2 where p1.town = p2.town);

實例3(all):獲取最老球員的號碼,名字及生日。(即出生日期數(shù)值小于或等于所有其它球員的球員)

mysql> select playerno, name, birth_date from players where birth_date <= all (select birth_date from players);

XISTS關(guān)鍵字表示存在。使用EXISTS關(guān)鍵字時,內(nèi)層查詢語句不返回查詢的記錄,而是返回一個真假值,如果內(nèi)層查詢語句查詢到滿足條件的記錄,只要子查詢中至少返回一個值,則EXISTS語句的值就為True。就返回true,否則返回false。當返回的值為true時,外層查詢語句將進行查詢,否則不進行查詢。NOT EXISTS剛好與之相反。exists的用法和in ()差不多,但是它們還是有區(qū)別的。主要是看兩個張表大小差的程度。若子查詢表大則用exists(內(nèi)層索引),子查詢表小則用in(外層索引);

實例1(exists):獲取那些至少支付了一次罰款的球員的名字和首字母。

mysql> select name, initials from players where exists (select * from penalties where playerno = players.playerno);

實例2(not exists):獲取那些從來沒有罰款的球員的名字和首字母。

mysql> select name, initials from players where not exists (select * from penalties where playerno = players.playerno);

以上就是實例詳解mysql子查詢的詳細內(nèi)容,更多關(guān)于mysql子查詢的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

相關(guān)文章:
主站蜘蛛池模板: 河北凯普威医疗器材有限公司,高档轮椅系列,推车系列,座厕椅系列,协步椅系列,拐扙系列,卫浴系列 | 塑料托盘厂家直销-吹塑托盘生产厂家-力库塑业【官网】 | 快干水泥|桥梁伸缩缝止水胶|伸缩缝装置生产厂家-广东广航交通科技有限公司 | 便携式XPDM露点仪-在线式防爆露点仪-增强型烟气分析仪-约克仪器 冰雕-冰雪世界-大型冰雕展制作公司-赛北冰雕官网 | 冷油器-冷油器换管改造-连云港灵动列管式冷油器生产厂家 | 铣刨料沥青破碎机-沥青再生料设备-RAP热再生混合料破碎筛分设备 -江苏锡宝重工 | 小型手持气象站-空气负氧离子监测站-多要素微气象传感器-山东天合环境科技有限公司 | 高速混合机_锂电混合机_VC高效混合机-无锡鑫海干燥粉体设备有限公司 | 合肥汽车充电桩_安徽充电桩_电动交流充电桩厂家_安徽科帝新能源科技有限公司 | 航空障碍灯_高中低光强航空障碍灯_民航许可认证航空警示灯厂家-东莞市天翔航天科技有限公司 | 拉力机-万能试验机-材料拉伸试验机-电子拉力机-拉力试验机厂家-冲击试验机-苏州皖仪实验仪器有限公司 | 雪花制冰机(实验室雪花制冰机)百科 | 武汉天安盾电子设备有限公司 - 安盾安检,武汉安检门,武汉安检机,武汉金属探测器,武汉测温安检门,武汉X光行李安检机,武汉防爆罐,武汉车底安全检查,武汉液体探测仪,武汉安检防爆设备 | 深圳离婚律师咨询「在线免费」华荣深圳婚姻律师事务所专办离婚纠纷案件 | Duoguan 夺冠集团 | 成都APP开发-成都App定制-成都app开发公司-【未来久】 | 河南橡胶接头厂家,河南波纹补偿器厂家,河南可曲挠橡胶软连接,河南套筒补偿器厂家-河南正大阀门 | 骨密度检测仪_骨密度分析仪_骨密度仪_动脉硬化检测仪专业生产厂家【品源医疗】 | 重庆网站建设,重庆网站设计,重庆网站制作,重庆seo,重庆做网站,重庆seo,重庆公众号运营,重庆小程序开发 | 塑胶地板-商用PVC地板-pvc地板革-安耐宝pvc塑胶地板厂家 | 美的商用净水器_美的直饮机_一级代理经销商_Midea租赁价格-厂家反渗透滤芯-直饮水批发品牌售后 | 碳化硅,氮化硅,冰晶石,绢云母,氟化铝,白刚玉,棕刚玉,石墨,铝粉,铁粉,金属硅粉,金属铝粉,氧化铝粉,硅微粉,蓝晶石,红柱石,莫来石,粉煤灰,三聚磷酸钠,六偏磷酸钠,硫酸镁-皓泉新材料 | 气力输送_输送机械_自动化配料系统_负压吸送_制造主力军江苏高达智能装备有限公司! | 济南宣传册设计-画册设计_济南莫都品牌设计公司 | Eiafans.com_环评爱好者 环评网|环评论坛|环评报告公示网|竣工环保验收公示网|环保验收报告公示网|环保自主验收公示|环评公示网|环保公示网|注册环评工程师|环境影响评价|环评师|规划环评|环评报告|环评考试网|环评论坛 - Powered by Discuz! | 消泡剂_水处理消泡剂_切削液消泡剂_涂料消泡剂_有机硅消泡剂_广州中万新材料生产厂家 | 行星齿轮减速机,减速机厂家,山东减速机-淄博兴江机械制造 | 钢板仓,大型钢板仓,钢板库,大型钢板库,粉煤灰钢板仓,螺旋钢板仓,螺旋卷板仓,骨料钢板仓 | 层流手术室净化装修-检验科ICU改造施工-华锐净化工程-特殊科室建设厂家 | 皮带机_移动皮带机_大倾角皮带机_皮带机厂家 - 新乡市国盛机械设备有限公司 | 鹤壁创新仪器公司-全自动量热仪,定硫仪,煤炭测硫仪,灰熔点测定仪,快速自动测氢仪,工业分析仪,煤质化验仪器 | 防火阀、排烟防火阀、电动防火阀产品生产销售商-德州凯亿空调设备有限公司 | 披萨石_披萨盘_电器家电隔热绵加工定制_佛山市南海区西樵南方综合保温材料厂 | 制氮设备-变压吸附制氮设备-制氧设备-杭州聚贤气体设备制造有限公司 | 直齿驱动-新型回转驱动和回转支承解决方案提供商-不二传动 | 北京发电机出租_发电机租赁_北京发电机维修 - 河北腾伦发电机出租 | 铝机箱_铝外壳加工_铝外壳厂家_CNC散热器加工-惠州市铂源五金制品有限公司 | 低气压试验箱_高低温低气压试验箱_低气压实验箱 |林频试验设备品牌 | 激光内雕_led玻璃_发光玻璃_内雕玻璃_导光玻璃-石家庄明晨三维科技有限公司 激光内雕-内雕玻璃-发光玻璃 | 上海公众号开发-公众号代运营公司-做公众号的公司企业服务商-咏熠软件 | 重庆监控_电子围栏设备安装公司_门禁停车场管理系统-劲浪科技公司 |