欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java mysql特殊形式的查詢語句詳解

 更新時間:2022年02月19日 11:18:48   作者:_卷心菜_  
這篇文章主要介紹了Java mysql特殊形式的查詢,包括子查詢和聯合查詢、自身連接查詢問題,本文通過sql語句給大家介紹的非常詳細,需要的朋友可以參考下

創(chuàng)建新表:

-- 創(chuàng)建學員表
CREATE TABLE IF NOT EXISTS stu(
id TINYINT UNSIGNED AUTO_INCREMENT KEY COMMENT '編號',
username VARCHAR(20) NOT NULL UNIQUE COMMENT '學員名稱',
score TINYINT UNSIGNED NOT NULL COMMENT '學員考試分數'
)ENGINE=INNODB;

INSERT stu(username, score) VALUES('king', 95),
('queen', 75),
('zhangsan', 69),
('lisi', 78),
('wangwu', 87),
('zhaoliu', 88),
('tianqi', 98),
('ceshi', 99),
('tiancai', 50);

-- 創(chuàng)建分數級別表
CREATE TABLE IF NOT EXISTS `level`(
id TINYINT UNSIGNED AUTO_INCREMENT KEY COMMENT '編號',
score TINYINT UNSIGNED COMMENT '分數'
)ENGINE=INNODB;

INSERT `level`(score) VALUES(90), (80), (70);

1. 子查詢

1.1. SELECT 字段名稱 FROM 表名 WHERE 字段名稱 = (SELECT 字段名稱 FROM 表名);

1.2. 內層語句查詢的結果可以作為外層語句查詢的條件

1.3. 由IN引發(fā)的子查詢

SELECT * FROM user1 WHERE depId IN (1, 2, 3, 4);

SELECT * FROM user1 
WHERE depId IN (SELECT id FROM dep);

1.4. 由比較運算符引出子查詢

SELECT id, username, score FROM stu
WHERE score >= (SELECT score FROM `level` WHERE id = 1);

1.5. 由EXISTS引發(fā)的子查詢

若EXISTS后的結果為真,則返回查詢的結果,否則返回結果為空。

SELECT * FROM stu WHERE EXISTS (SELECT score FROM `level` WHERE id = 1);

1.6. ANY SOME ALL

在這里插入圖片描述

取ANY|SOME|ALL后的括號中的查詢結果的最小值或最大值。

-- ANY SOME ALL
SELECT * FROM stu WHERE score >= ANY(SELECT score FROM `level`);
SELECT * FROM stu WHERE score > SOME(SELECT score FROM `level`);
SELECT * FROM stu WHERE score > ALL(SELECT score FROM `level`);

1.7. CREATE …SELECT

-- 創(chuàng)建一個user3表,將表stu中的id, username的信息寫入user3中
CREATE TABLE user3(
id INT UNSIGNED AUTO_INCREMENT KEY,
username VARCHAR(20)
) SELECT id, username FROM stu;

1.8. INSERT…SELECT

-- 將user1表中的username信息插入到user3中
INSERT user3(username) SELECT username FROM user1;

1.9. CREATE TABLE 表名1 LIKE 表名2;

創(chuàng)建和表2結構相同的表1。

2.聯合查詢

2.1 UNION

去掉兩個表中的重復值。

SELECT 字段名稱,… FROM 表名1
UNION
SELECT 字段名稱,… FROM 表名2;

2.2 UNION ALL

只是將兩個表進行簡單的合并,不會去掉重復值。

SELECT 字段名稱,… FROM 表名1
UNION ALL 
SELECT 字段名稱,… FROM 表名2;

3. 自身連接查詢

3.1. 無限級分類的實現形式

創(chuàng)建表cate:

-- 創(chuàng)建表cate
CREATE TABLE cate(
id SMALLINT UNSIGNED AUTO_INCREMENT KEY COMMENT '編號',
cateName VARCHAR(100) NOT NULL UNIQUE COMMENT '分類名稱',
pId SMALLINT UNSIGNED NOT NULL DEFAULT 0 COMMENT '父id'
);

-- 插入頂級分類
INSERT cate(cateName, pId) VALUES('服裝', 0),
('數碼', 0),
('玩具', 0),
-- 插入服裝的子分類
('男裝', 1),
('女裝', 1),
('內衣', 1),  
-- 插入數碼的子分類
('電視', 2),
('冰箱', 2),
('洗衣機', 2),
-- 插入玩具的子分類
('愛馬仕', 3),
('LV', 3),
('GUCCI', 3),
-- 插入男裝的子分類
('夾克', 4),
('襯衫', 4),
('褲子', 4),
-- 插入電視的子分類
('液晶電視', 7),
('等離子電視', 7),
('背投電視', 7);

在這里插入圖片描述

自身連接:

-- 查詢所有的分類信息,并且得到其父分類
SELECT s.id, s.cateName AS sCateName, p.cateName AS pCateName
FROM cate AS s
LEFT JOIN cate AS p
ON s.pId = p.id;

在這里插入圖片描述

到此這篇關于Java mysql特殊形式的查詢的文章就介紹到這了,更多相關Java mysql查詢內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Spring中IoC優(yōu)點與缺點解析

    Spring中IoC優(yōu)點與缺點解析

    這篇文章主要為大家詳細解析了Spring中IoC優(yōu)點與缺點,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • Eclipse配置maven環(huán)境的圖文教程

    Eclipse配置maven環(huán)境的圖文教程

    下面小編就為大家?guī)硪黄狤clipse配置maven環(huán)境的圖文教程。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • Java 詳解單向加密--MD5、SHA和HMAC及簡單實現實例

    Java 詳解單向加密--MD5、SHA和HMAC及簡單實現實例

    這篇文章主要介紹了Java 詳解單向加密--MD5、SHA和HMAC及簡單實現實例的相關資料,需要的朋友可以參考下
    2017-02-02
  • Spring的循環(huán)依賴、三級緩存解決方案源碼詳細解析

    Spring的循環(huán)依賴、三級緩存解決方案源碼詳細解析

    這篇文章主要介紹了Spring的循環(huán)依賴、三級緩存解決方案源碼詳細解析,在Spring中,由于IOC的控制反轉,創(chuàng)建對象不再是簡單的new出來,而是交給Spring去創(chuàng)建,會經歷一系列Bean的生命周期才創(chuàng)建出相應的對象,需要的朋友可以參考下
    2024-01-01
  • Spring Security 實現短信驗證碼登錄功能

    Spring Security 實現短信驗證碼登錄功能

    這篇文章主要介紹了Spring Security 實現短信驗證碼登錄功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • SpringBoot源碼 PropertySource解析

    SpringBoot源碼 PropertySource解析

    PropertySource是spring中對于鍵值屬性的一種抽象,主要是name和sourcePropertyResolver是對PropertySource提供對外的統(tǒng)一數據處理,對于占位符的處理委托于PropertyPlaceholderHelper,對Springboot?源碼 PropertySource相關知識感興趣的朋友一起看看吧
    2023-01-01
  • SpringBoot(cloud)自動裝配bean找不到類型的問題

    SpringBoot(cloud)自動裝配bean找不到類型的問題

    這篇文章主要介紹了SpringBoot(cloud)自動裝配bean找不到類型的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • Java數組擴容的三大小結

    Java數組擴容的三大小結

    當數組需要容納更多元素時,可以通過擴容來增加其容量,本文主要介紹了Java數組擴容的三大小結,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-08-08
  • Mybatis動態(tài)SQL之where標簽用法說明

    Mybatis動態(tài)SQL之where標簽用法說明

    這篇文章主要介紹了Mybatis動態(tài)SQL之where標簽用法說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • java連接mysql數據庫亂碼的解決方法

    java連接mysql數據庫亂碼的解決方法

    這篇文章主要介紹通過java連接mysql數據庫的時候,頁面出現亂碼,這里簡單分享下解決方法, 需要的朋友可以參考下
    2013-05-05

最新評論