數據庫---四中連接查詢(交叉、左連接、右連接、完整查詢)

個人博客 :https://www.siyuan.run
CSDN:https://blog.csdn.net/siyuan
微信小程序:思遠Y

1、交叉連接查詢 :?(基本不適用---得到的是兩張表數據的乘積)

語法:SELECT * FROM 表1,表2;
PS:與表關系無關
示例:
圖1:products表數據信息
?

圖2:category表數據信息

?
SELECT * FROM products,category;#執行該語句后顯示的效果如圖3
圖3:查詢結果
?

2、內連接查詢

概念:內連接是等值連接,它使用比較運算符(=、>、<、<>...)根據每個表共有的列的值匹配兩個表中的行。
分類:

隱式內連接:SELECT * FROM 表A,表B... WHERE 條件;(條件:表A和表B的等值關系)

圖4:products表數據信息
?
圖5:category表數據信息
?
SELECT * FROM CATEGORY,PRODUCTS WHERE PRODUCTS.CATEGORY_ID=CATEGORY.CID;
使用別名:
SELECT * FROM CATEGORY C,PRODUCTS P WHERE P.CATEGORY=C.CID;
圖6:查詢結果
?

顯示內連接:SELECT * FROM 表A,表B... INNER JOIN;(INNER可以省略)

SELECT *?
FROM CATEGORY?
INNER JOIN PRODUCTS ON CATEGORY.CID=PRODUCTS.CATEGORY_ID;
使用別名:請參照上面例子

圖7:查詢結果 如圖6

?

三表內連接查詢:假設再添加一張訂單ORDER表.
圖8:ORDER表
?
SELECT *?
FROM CATEGORY C?
INNER JOIN PRODUCTS P ON C.CID=P.CATEGORY_ID?
INNER JOIN ORDERS O ON O.CID=P.CATEGORY_ID;
圖9:顯示結果
?

3、外連接查詢:外連接分為左連接查詢,右連接查詢,完整連接查詢

3.1左連接:左連接又稱左向外連接,查詢的結果集包括LEFT OUTER子句中指定的坐標的所有行,而不僅僅是連接列所匹配的行。如果左表的某行在右表中沒有匹配行,則在相關聯的結果集行中右表的所有選擇列表列均為空值。?

使用的關鍵字:LEFT OUTER JOIN(OUTER可省略)
SELECT *?
FROM PRODUCTS?
LEFT OUTER JOIN CATEGORY ON PRODUCTS.CATEGORY_ID=CATEGORY.CID;
圖10:結果顯示
?

3.2右連接:右向外聯接是左向外聯接的反向聯接。將返回右表的所有行。如果右表的某行在左表中沒有匹配行,則將為左表返回空值。

使用的關鍵字:RIGHT OUTER JOIN(OUTER可以省略)
SELECT *?
FROM PRODUCTS?
RIGHT OUTER JOIN CATEGORY ON PRODUCTS.CATEGORY_ID=CATEGORY.CID;
圖11:顯示結果
?

3.3完整連接:完整外部聯接返回左表和右表中的所有行。當某行在另一個表中沒有匹配行時,則另一個表的選擇列表列包含空值。如果表之間有匹配行,則整個結果集行包含基表的數據值。

使用的關鍵字:FULL OUTER JOIN(OUTER可以省略)
SELECT *?
FROM PRODUCTS?
FULL OUTER JOIN CATEGORY ON PRODUCTS.category_id=CATEGORY.cid;

圖12:略

?

互相學習,有錯請指教!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/273745.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/273745.shtml
英文地址,請注明出處:http://en.pswp.cn/news/273745.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

如何用C#語言構造蜘蛛程序

"蜘蛛"&#xff08;Spider&#xff09;是Internet上一種很有用的程序&#xff0c;搜索引擎利用蜘蛛程序將Web頁面收集到數據庫&#xff0c;企業利用蜘蛛程序監視競爭對手的網站并跟蹤變動&#xff0c;個人用戶用蜘蛛程序下載Web頁面以便脫機使用&#xff0c;開發者利…

數據庫---練習題(45道)

準備工作 CREATE DATABASE STUDENTS; CREATE TABLE STUDENT( SNO VARCHAR(32) PRIMARY KEY NOT NULL, SNAME VARCHAR(32) NOT NULL, SSEX VARCHAR(32) NOT NULL, SBIRTHDAY DATETIME, CLASS VARCHAR(20) ); CREATE TABLE COURSE( CNO VARCHAR(20) PRIMARY KEY NOT NULL, CNAM…

LeetCode OJ - Populating Next Right Pointers in Each Node II

題目&#xff1a; Follow up for problem "Populating Next Right Pointers in Each Node". What if the given tree could be any binary tree? Would your previous solution still work? Note: You may only use constant extra space.For example,Given the fo…

數據庫---JDBC

1.1 JDBC概述JDBC&#xff08;Java DataBase Connectivity,java數據庫連接&#xff09;是一種用于執行SQL語句的Java API。JDBC是Java訪問數據庫的標準規范&#xff0c;可以為不同的關系型數據庫提供統一訪問&#xff0c;它由一組用Java語言編寫的接口和類組成。 JDBC需要連接驅…

23種設計模式之簡單工廠

簡單工廠模式描述的是&#xff0c;通過類的繼承關系&#xff0c;父類&#xff08;工廠類&#xff09;與子類&#xff08;產品類&#xff09;&#xff0c;調用父類中的方法&#xff0c;實際干活兒的是子類中的方法&#xff1b;封裝需求的不確定性&#xff0c;做出通用的編程&…

原生JDBC操作數據庫流程

1、class.forName()加載數據驅動 2、DriverManager.getConnection()獲取數據庫連接對象。 3、根據SQL或sql會話對象&#xff0c;有兩種方式Statement、PreparedStatement。 4、執行sql處理結果集&#xff0c;如果有參數就設置參數。 5、關閉結果集&#xff0c;關閉會話&#xf…

verilog HDL 編碼風格

1、有意義且有效的名字。 2、同一信號在不同層次應該保持一致。 3、添加有意義的后綴&#xff0c;使信號的有效性更加明確。 4、模塊輸出寄存器化&#xff0c;使得輸出的驅動強度和輸入延時是可以預測的。 5、使用括號表明優先級。 6、每一個if都應該有一個else。如果esle沒有任…

為什么要使用PreparedStatement

(個人理解&#xff1a;執行速度&#xff0c;使用方便&#xff0c;代碼的可讀性維護性&#xff0c;提高性能&#xff0c;安全性 五個方面考慮) 1、PreparedStatement接口繼承Statement&#xff0c;PreparedStatement實例包含了預編譯的SQL語句&#xff0c;所以PreparedStatement…

session中存放一個對象,只修改對象的屬性,不將修改后的對象存放session,發現session中存放的對象也發生改變!

標題簡單描述&#xff1a;先將一個對象放入session&#xff0c;只對對象屬性值進行修改&#xff0c;但不將修改后的對象存放session中&#xff0c;發現session中存放的對象屬性值也相對應的改變。Person personnew PerSon(); request.getSession().setAttribute("person&q…

利用三層交換機實現VLAN間路由配置

利用三層交換機實現VLAN間路由配置 實驗目標&#xff1a; 一、 掌握交換機Tag VLAN的配置&#xff1b; 二、掌握三層交換機基本配置方法&#xff1b; 三、 掌握三層交換機的VLAN路由的配置方法&#xff1b; 四、通過三層交換機實現VLAN見相互通信&#xff1b; 技術原理&#xf…

Maven,在pom.xml配置JDK 9版本。

<build><plugins><!-- 設置JDK 9版本 --><plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <configuration> …

【leetcode】Path Sum II

Given a binary tree and a sum, find all root-to-leaf paths where each paths sum equals the given sum. For example:Given the below binary tree and sum 22, 5/ \4 8/ / \11 13 4/ \ / \7 2 5 1 return [[5,4,11,2],[5,8,4,5] ] 下午做了個筆試沒睡覺…

easyui、表格中添加操作一列,將操作下設置為修改,點擊修改彈出該行對象的編號。

頁面中的代碼(自己引入easy插件)&#xff1a; <body> <div id"table"></div> </body> <script type"text/javascript"> $(function(){$(#table).datagrid({ url:tt.json, //顯示的數據striped:true, …

被LTRIM(RTRIM())害死了,差點

LTRIM(character_expression)去掉前置空格 LTRIM(RTRIM())就是把前置和后置空格都去掉。 character_expression可以是常量、變量或列。character_expression必須屬于某個可隱式轉換為varchar的數據類型(text、ntext和image除外)。否則&#xff0c;請使用CAST顯示轉換character_…

Mybatis、使用注解的方式編寫用戶和角色一對多關系,并使用延遲加載

1、數據庫準備 CREATE TABLE role ( ID INT(11) NOT NULL COMMENT 編號,ROLE_NAME VARCHAR(30) DEFAULT NULL COMMENT 角色名稱,ROLE_DESC VARCHAR(60) DEFAULT NULL COMMENT 角色描述,PRIMARY KEY (ID) ) ENGINEINNODB DEFAULT CHARSETutf8;INSERT INTO role(ID,ROLE_NAME,…

織夢標簽大全

關鍵描述調用標簽&#xff1a; <meta name"keywords" content"{dede:field namekeywords/}"> <meta name"description" content"{dede:field namedescription functionhtml2text(me)/}"> -------------------------------…

spring的注入

1、構造函數注入的是設計到的標簽&#xff1a;constructor-arg屬性&#xff1a;index:指定參數在構造函數參數列表的索引位置type:指定參數在構造函數中的數據類型name:指定參數在構造函數中的名稱上面三個都是找誰 &#xff0c;給誰賦值&#xff0c;下面兩個指的是賦什么值 va…

.Net中堆棧和堆的區別

首先堆棧和堆&#xff08;托管堆&#xff09;都在進程的虛擬內存中。&#xff08;在32位處理器上每個進程的虛擬內存為4GB&#xff09; 堆棧stack 1、堆棧中存儲值類型 2、堆棧實際上是向下填充&#xff0c;即由高內存地址指向低內存地址填充 3、堆棧的工作方式是先分配內存的變…

spring的IOC注解

1、創建對象的注解 含義&#xff1a;使用注解的形式創建對象&#xff0c;交給Spring容器管理(需要配置在類上) Component:組件 Controller:web層 Service:service層 Repository:Dao層默認&#xff1a;創建對象的唯一標識&#xff0c;當前類名首字母小寫value屬性&#xff1a;指…

PowerDesigner 逆向工程 從SQL文件轉換成PDM 從PDM轉成CDM

從SQL文件逆向工程到PDM&#xff1a; ①選擇file -> Reverse Engineer - > Database ②在General選項卡中選擇MySQL數據庫&#xff0c;點擊確定。 ③using script file 選擇你的sql文件&#xff0c;最后選擇確定。 從PDM轉成CDM&#xff1a; ①選擇工具 -> General CD…