SQL中部分語法整理

来源:http://www.cnblogs.com/xunlizhizuo/archive/2016/11/22/6089452.html
-Advertisement-
Play Games

1.SELECT DISTINCT 語句 關鍵詞DISTINCT用於返回唯一不同的值。 語法: SELECT DISTINCT 列名稱 FROM 表名稱 2.SELECT INTO語句 SELECT INTO語句從一個表中選取數據,然後把數據插入另一個表中。 SELECT INTO語句常用於創建表的 ...


1.SELECT DISTINCT 語句

 關鍵詞DISTINCT用於返回唯一不同的值。

    語法:

    SELECT DISTINCT 列名稱 FROM 表名稱

2.SELECT INTO語句

    SELECT INTO語句從一個表中選取數據,然後把數據插入另一個表中。

    SELECT INTO語句常用於創建表的備份復件或者用於對記錄進行存檔。

    SQL SELECT INTO語法

    把所有的列插入新表: 

    SELECT   *

    INTO new_table_name [IN externaldatabase]

    FROM old_tablename

    或者只把希望的列插入新表:

    SELECT column_name(s)

    INTO new_table_name [IN externaldatabase]

    FROM old_tablename

    其中,IN子句可用於向另一個資料庫中拷貝表:

    示例: SELECT * INTO Persons  IN  'Backup.mdb'  FROM  Persons

 如果我們希望拷貝某些域,可以在SELECT語句後列出這些域:

    示例:SELECT LastName,FirstName INTO Persons_backup From Persons

3.SQL UNION操作符

    UNION操作符用於合併兩個或多個SELECT語句的結果集。

    請註意,UNION內部的SELECT語句必須擁有相同數量的列。列也必須擁有相似的數據類型。

    同時,每條SELECT語句中的列的順序必須相同。

    SQL UNION語法

    SELECT column_name(s) from table_name1

    UNION 

    SELECT column_name(s) from table_name2

    預設地,UNION操作符選取不同的值。如果允許重覆的值,請使用UNION ALL。

    SQL UNION ALL語法

    SELECT column_name(s) FROM table_name1

    UNION ALL

    SELECT column_name(s) FROM table_name2

    另外,UNION結果集中的列名總是等於UNION中第一個SELECT語句中的列名.

4.SQL JOIN 

    SQL join用於根據兩個或多個表中的列之間的關係,從這些表中查詢數據。

    Join和Key

    有時為了得到完整的結果,我們需要從兩個或更多的表中獲取結果。我們就需要執行join。

    資料庫中的表可通過鍵將彼此聯繫起來。主鍵(Primary Key)是一個列,在這個列中的每一行的值都是唯一的。

    在表中,每個主鍵的值都是唯一的。這樣做的目的是在不重覆每個表中的所有數據的情況下,把表間的數據交叉捆綁在一起。

    不同的SQL JOIN

    下麵列出了你可以使用的JOIN類型,以及它們之間的差異。

  • JOIN:如果表中有至少一個匹配,則返回行
  • LEFT JOIN:即使右表中沒有匹配,也從左表返回所有的行
  • RIGHT JOIN:即使左表中沒有匹配,也從右表返回所有的行
  • FULL JOIN:只要其中一個表存在匹配,就返回行     

5.SQL INNER JOIN關鍵字

    在表中存在至少一個匹配時,INNER JOIN關鍵字返回行

    INNER JOIN關鍵字語法

    SELECT column_name(s)

    FROM table_name1

    INNER JOIN table_name2

    ON table_name1.column_name = table_name2.column_name

6.SQL LEFT JOIN關鍵字

    LEFT JOIN關鍵字會從左表那裡返回所有的行,即使在右表(table_name2)中沒有匹配的行。

    LEFT JOIN關鍵字語法

    SELECT column_name(s)

    FROM table_name1

    LEFT JOIN table_name2

    ON table_name1.column_name = table_name2.column_name

    註釋:在某些資料庫中,LEFT JOIN稱為LEFT OUTER JOIN

7.SQL Right JOIN關鍵字

    RIGHT JOIN關鍵字會右表(table_name2)那裡返回所有的行,即使在左表(table_nam1)中沒有匹配的行。

    RIGHT JOIN關鍵字語法:

    SELECT column_name(s)

    From table_name1

    RIGHT JOIN table_name2

    ON table_name1.column_name = table_name2.column_name

    註釋:在某些資料庫中,RIGHT JOIN稱為RIGHT OUTER JOIN。

8.SQL FULL JOIN關鍵字

   只要其中某個表存在匹配,FULL JOIN關鍵字就會返回行。

   FULL JOIN關鍵字語法

   SELECT column_name(s)

   FROM table_name1

   FULL JOIN table_name2

   ON table_name1.column_name = table_name2.column_name

   註釋:在某些資料庫中,FULL JOIN稱為FULL OUTER JOIN。

 

 

 

 

 

 

  (未完,待續....)


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.列級約束語法 create table primary_test ( -- 建立主鍵約束 test_id int primary key, test_name varchar(20), test_pass varchar(20) ); 2.表級約束語法 create table primary_ ...
  • 修改欄位預設值-查找欄位的約束名稱 刪除約束 修改預設值約束 獲取表列的預設值 ...
  • 1.打開資料庫:找到表,雙擊要插入的表打開: 2.打開之後點擊文件->查詢表 3.輸入要查詢的語句,點擊運行。成功後會有提示。 ...
  • oracle: 一、數據 db數據欄位如下: task_id task_name t.parent_task_id *** *** *** *** *** 000001 t1 *** *** 000002 t11 000001 *** 000005 t12 000001 *** 000003 t11 ...
  • 這是最基礎的用法: LISTAGG(XXX,XXX) WITHIN GROUP( ORDER BY XXX) 例: select listagg(oeid,',') within GROUP (order by oeid) ...
  • Master/Slave主從複製 主從複製MongoDB中比較常用的一種方式,如果要實現主從複製至少應該有兩個MongoDB實例,一個作為主節點負責客戶端請求,另一個作為從節點負責從主節點映射數據,提供數據備份,客戶端讀取等,推薦一主多從模式 MongoDB主從複製的實現方式: 主節點的操作會被記錄... ...
  • 11g新特性:Health Monitor Checks 一、什麼是Health Monitor Checks Health Monitor Checks能夠發現文件損壞,物理、邏輯塊損壞,undo、redo損壞,數據字典損壞等等。 Health Monitor Checks產生結果報告,它包含瞭解 ...
  • Sqoop的使用應該是Oozie裡面最常用的了,因為很多BI數據分析都是基於業務資料庫來做的,因此需要把mysql或者oracle的數據導入到hdfs中再利用mapreduce或者spark進行ETL,生成報表信息。 因此本篇的Sqoop Action其實就是運行一個sqoop的任務而已。 同樣ac ...
一周排行
    -Advertisement-
    Play Games
  • C#TMS系統代碼-基礎頁面BaseCity學習 本人純新手,剛進公司跟領導報道,我說我是java全棧,他問我會不會C#,我說大學學過,他說這個TMS系統就給你來管了。外包已經把代碼給我了,這幾天先把增刪改查的代碼背一下,說不定後面就要趕鴨子上架了 Service頁面 //using => impo ...
  • 委托與事件 委托 委托的定義 委托是C#中的一種類型,用於存儲對方法的引用。它允許將方法作為參數傳遞給其他方法,實現回調、事件處理和動態調用等功能。通俗來講,就是委托包含方法的記憶體地址,方法匹配與委托相同的簽名,因此通過使用正確的參數類型來調用方法。 委托的特性 引用方法:委托允許存儲對方法的引用, ...
  • 前言 這幾天閑來沒事看看ABP vNext的文檔和源碼,關於關於依賴註入(屬性註入)這塊兒產生了興趣。 我們都知道。Volo.ABP 依賴註入容器使用了第三方組件Autofac實現的。有三種註入方式,構造函數註入和方法註入和屬性註入。 ABP的屬性註入原則參考如下: 這時候我就開始疑惑了,因為我知道 ...
  • C#TMS系統代碼-業務頁面ShippingNotice學習 學一個業務頁面,ok,領導開完會就被裁掉了,很突然啊,他收拾東西的時候我還以為他要旅游提前請假了,還在尋思為什麼回家連自己買的幾箱飲料都要叫跑腿帶走,怕被偷嗎?還好我在他開會之前拿了兩瓶芬達 感覺感覺前面的BaseCity差不太多,這邊的 ...
  • 概述:在C#中,通過`Expression`類、`AndAlso`和`OrElse`方法可組合兩個`Expression<Func<T, bool>>`,實現多條件動態查詢。通過創建表達式樹,可輕鬆構建複雜的查詢條件。 在C#中,可以使用AndAlso和OrElse方法組合兩個Expression< ...
  • 閑來無聊在我的Biwen.QuickApi中實現一下極簡的事件匯流排,其實代碼還是蠻簡單的,對於初學者可能有些幫助 就貼出來,有什麼不足的地方也歡迎板磚交流~ 首先定義一個事件約定的空介面 public interface IEvent{} 然後定義事件訂閱者介面 public interface I ...
  • 1. 案例 成某三甲醫預約系統, 該項目在2024年初進行上線測試,在正常運行了兩天後,業務系統報錯:The connection pool has been exhausted, either raise MaxPoolSize (currently 800) or Timeout (curren ...
  • 背景 我們有些工具在 Web 版中已經有了很好的實踐,而在 WPF 中重新開發也是一種費時費力的操作,那麼直接集成則是最省事省力的方法了。 思路解釋 為什麼要使用 WPF?莫問為什麼,老 C# 開發的堅持,另外因為 Windows 上已經裝了 Webview2/edge 整體打包比 electron ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...