目錄
UNION
相同數量的欄位
  好了,以上就是SQL中的UNION關鍵字用法,感謝您的閱讀,希望您喜歡,如對您有幫助,歡迎點讚收藏。如有不足之處,歡迎評論指正。下次見。
首頁 資料庫 SQL SQL入門學習之淺析UNION關鍵字的用法

SQL入門學習之淺析UNION關鍵字的用法

Feb 21, 2022 am 10:55 AM
sql

我們在開發過程中常常會使用到將多個查詢結果都直接顯示出來,那麼應該怎麼查詢呢?這篇文章進行學習SQL,來一起看看SQL中的UNION關鍵字,看看它要怎麼使用,希望對大家有幫助!

SQL入門學習之淺析UNION關鍵字的用法

SQL中的UNION關鍵字,將實作將多個查詢條件中的結果顯示出來。

UNION

  UNION的中文意義是聯合的意思,即合併兩個或多個 SELECT 語句的結果。使用技巧如下:

  • UNION 內部的每個 SELECT 語句必須擁有相同數量的欄位。
  • 列必須擁有相似的資料型別。
  • 每個 SELECT 語句中的欄位的順序必須相同。

相同數量的欄位

如下圖,使用上一章介紹的資料作為示範資料

SQL入門學習之淺析UNION關鍵字的用法

##分別建立表

s_user 和表格s_user_1

CREATE TABLE `s_user` (
  `userid` int(11) NOT NULL AUTO_INCREMENT,
  `user_name` varchar(255) DEFAULT NULL,
  `name` varchar(255) DEFAULT NULL,
  `pass_word` varchar(255) DEFAULT NULL,
  `salt` varchar(255) DEFAULT NULL,
  `state` varchar(255) DEFAULT NULL,
  `create_time` datetime DEFAULT NULL,
  PRIMARY KEY (`userid`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
登入後複製

測試資料如下:

INSERT INTO `test`.`s_user`(`userid`, `user_name`, `name`, `pass_word`, `salt`, `state`, `create_time`) VALUES (1, '小米', '小米', '123123', '123', '1', '2022-02-10 19:48:43');
INSERT INTO `test`.`s_user`(`userid`, `user_name`, `name`, `pass_word`, `salt`, `state`, `create_time`) VALUES (2, '小白', '小白', '123123', '123', '1', '2022-02-10 19:48:43');

INSERT INTO `test`.`s_user_1`(`userid`, `user_name`, `name`, `pass_word`, `salt`, `state`, `create_time`) VALUES (1, '小红', '小红', '123123', '123', '1', '2022-02-10 19:48:43');
INSERT INTO `test`.`s_user_1`(`userid`, `user_name`, `name`, `pass_word`, `salt`, `state`, `create_time`) VALUES (2, '小黄', '小黄', '123123', '123', '1', '2022-02-10 19:48:43');
登入後複製

UNION 內部的每個SELECT 語句必須擁有相同數量的欄位:先查詢具有相同列的SQL

SELECT * FROM `s_user` UNION SELECT * FROM `s_user_1`
登入後複製

查詢出所有的列,可以看到,執行結果如下。

SQL入門學習之淺析UNION關鍵字的用法

如果第一個查詢是所有列,第二個查詢是三個字段,那麼查詢結果又是怎麼樣呢,現在執行如下SQL:

錯誤用法

SELECT * FROM `s_user` UNION SELECT userid,name,pass_word FROM `s_user_1`
登入後複製

SQL入門學習之淺析UNION關鍵字的用法

#錯誤提示:使用的SELECT語句查詢出不同的列數

正確用法

SELECT userid,name,pass_word  FROM `s_user` UNION SELECT userid,name,pass_word FROM `s_user_1`
登入後複製

SQL入門學習之淺析UNION關鍵字的用法

#資料類型

  上面看到了多個查詢的列數必須相同,那麼查詢出的列數如果相同,查詢欄位的資料類型不同,是否可正常處理呢?以下將s_user查詢中的pass_word換成create_time,進行查詢。透過查詢之後可以看到。在SQL查詢中,列的資料類型是無關的。當然實際業務中是不會將其設定成不同的類型的。

SELECT userid,name,create_time  FROM `s_user` UNION SELECT pass_word,name,userid FROM `s_user_1`
登入後複製

SQL入門學習之淺析UNION關鍵字的用法

列順序

  在使用UNION關鍵字進行查詢時,是否和列的順序有關呢,上面看到可能和列的順序有關,可能也是無關的,那麼進行一下測試。可以看到執行結果是和列的順序無關的。在實際業務中是合併多個查詢,因此我們在專案中定義是需要列的順序一致的。

SELECT create_time,userid,name  FROM `s_user` UNION SELECT pass_word,name,userid FROM `s_user_1`
登入後複製

SQL入門學習之淺析UNION關鍵字的用法

UNION 和UNION ALL區別

#  為了測試UNION 和UNION ALL區別需要在資料表s_user_1中增加【小白】,與表s_user中的【小白】都存在資料庫中,兩個會有什麼不同結果。

INSERT INTO `test`.`s_user_1`(`userid`, `user_name`, `name`, `pass_word`, `salt`, `state`, `create_time`) VALUES (3, '小白', '小白', '123123', '123', '1', '2022-02-10 19:48:43');
登入後複製

SQL入門學習之淺析UNION關鍵字的用法

首先執行:

SELECT user_name,name,pass_word,salt
FROM `s_user` UNION SELECT user_name,name,pass_word,salt FROM `s_user_1`
登入後複製

執行結果:

SQL入門學習之淺析UNION關鍵字的用法

再次執行##
SELECT user_name,name,pass_word,salt
FROM `s_user` UNION ALL SELECT user_name,name,pass_word,salt FROM `s_user_1`
登入後複製

執行結果:

SQL入門學習之淺析UNION關鍵字的用法  可以看到UNION關聯的移除了重複項,而UNION ALL查詢出了所有的值,沒有移除重複資料。

結語

  好了,以上就是SQL中的UNION關鍵字用法,感謝您的閱讀,希望您喜歡,如對您有幫助,歡迎點讚收藏。如有不足之處,歡迎評論指正。下次見。

推薦學習:

mysql影片教學

#

以上是SQL入門學習之淺析UNION關鍵字的用法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Hibernate 框架中 HQL 和 SQL 的差異是什麼? Hibernate 框架中 HQL 和 SQL 的差異是什麼? Apr 17, 2024 pm 02:57 PM

HQL和SQL在Hibernate框架中進行比較:HQL(1.物件導向語法,2.資料庫無關的查詢,3.類型安全),而SQL直接操作資料庫(1.與資料庫無關的標準,2.可執行複雜查詢和資料操作)。

Oracle SQL中除法運算的用法 Oracle SQL中除法運算的用法 Mar 10, 2024 pm 03:06 PM

《OracleSQL中除法運算的用法》在OracleSQL中,除法運算是常見的數學運算之一。在資料查詢和處理過程中,除法運算可以幫助我們計算欄位之間的比例或得出特定數值的邏輯關係。本文將介紹OracleSQL中除法運算的用法,並提供具體的程式碼範例。一、OracleSQL中除法運算的兩種方式在OracleSQL中,除法運算可以用兩種不同的方式來進行

Oracle與DB2的SQL語法比較與區別 Oracle與DB2的SQL語法比較與區別 Mar 11, 2024 pm 12:09 PM

Oracle和DB2是兩個常用的關聯式資料庫管理系統,它們都有自己獨特的SQL語法和特性。本文將針對Oracle和DB2的SQL語法進行比較與區別,並提供具體的程式碼範例。資料庫連接在Oracle中,使用以下語句連接資料庫:CONNECTusername/password@database而在DB2中,連接資料庫的語句如下:CONNECTTOdataba

詳解MyBatis動態SQL標籤中的Set標籤功能 詳解MyBatis動態SQL標籤中的Set標籤功能 Feb 26, 2024 pm 07:48 PM

MyBatis動態SQL標籤解讀:Set標籤用法詳解MyBatis是一個優秀的持久層框架,它提供了豐富的動態SQL標籤,可以靈活地建構資料庫操作語句。其中,Set標籤是用來產生UPDATE語句中SET子句的標籤,在更新作業中非常常用。本文將詳細解讀MyBatis中Set標籤的用法,以及透過具體的程式碼範例來示範其功能。什麼是Set標籤Set標籤用於MyBati

SQL中的identity屬性是什麼意思? SQL中的identity屬性是什麼意思? Feb 19, 2024 am 11:24 AM

SQL中的Identity是什麼,需要具體程式碼範例在SQL中,Identity是一種用於產生自增數字的特殊資料類型,它常用於唯一識別表中的每一行資料。 Identity欄位通常與主鍵列搭配使用,可確保每筆記錄都有獨一無二的識別碼。本文將詳細介紹Identity的使用方式以及一些實際的程式碼範例。 Identity的基本使用方式在建立表格時,可以使用Identit

Springboot+Mybatis-plus不使用SQL語句進行多表新增怎麼實現 Springboot+Mybatis-plus不使用SQL語句進行多表新增怎麼實現 Jun 02, 2023 am 11:07 AM

在Springboot+Mybatis-plus不使用SQL語句進行多表添加操作我所遇到的問題準備工作在測試環境下模擬思維分解一下:創建出一個帶有參數的BrandDTO對像模擬對後台傳遞參數我所遇到的問題我們都知道,在我們使用Mybatis-plus中進行多表操作是極其困難的,如果你不使用Mybatis-plus-join這一類的工具,你只能去配置對應的Mapper.xml文件,配置又臭又長的ResultMap,然後再寫對應的sql語句,這種方法雖然看上去很麻煩,但具有很高的靈活性,可以讓我們

SQL出現5120錯誤怎麼解決 SQL出現5120錯誤怎麼解決 Mar 06, 2024 pm 04:33 PM

解決方法:1、檢查登入使用者是否具有足夠的權限來存取或操作該資料庫,確保該使用者俱有正確的權限;2、檢查SQL Server服務的帳戶是否具有存取指定檔案或資料夾的權限,確保該帳戶具有足夠的權限來讀取和寫入該文件或資料夾;3、檢查指定的資料庫文件是否已被其他進程打開或鎖定,嘗試關閉或釋放該文件,並重新運行查詢;4、嘗試以管理員身份運行Management Studio等等。

如何使用SQL語句在MySQL中進行資料聚合和統計? 如何使用SQL語句在MySQL中進行資料聚合和統計? Dec 17, 2023 am 08:41 AM

如何使用SQL語句在MySQL中進行資料聚合和統計?在進行資料分析和統計時,資料聚合和統計是非常重要的步驟。 MySQL作為一個功能強大的關聯式資料庫管理系統,提供了豐富的聚合和統計函數,可以很方便地進行資料聚合和統計操作。本文將介紹使用SQL語句在MySQL中進行資料聚合和統計的方法,並提供具體的程式碼範例。一、使用COUNT函數進行計數COUNT函數是最常用

See all articles