91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

數據庫基本操作語法歸納總結

發布時間:2020-09-10 23:01:06 來源:腳本之家 閱讀:203 作者:向往的生活 欄目:編程語言

關系型數據庫:以表作為實體,以主鍵和外鍵關系作為聯系的一種數據結構。

主鍵:在關系型數據庫中,用一個唯一的標識符來標志每一行,這個標識符就是主鍵。主鍵有兩個特點:非空和不能重復。

外鍵:在關系型數據庫中,外鍵就是用來表達表與表之間的關系、聯系,通過主外鍵關系,建立實體之間的聯系。

表之間的三種基本關系模型:

      ① 一對多關系: 一條主表記錄對應多條從表記錄,一條從表記錄對應一條主表記錄。

      ② 一對一關系: 一條主表記錄對應一條從表記錄,一條從表記錄對應一條主表記錄。

      ③ 多對多關系: 一條主表記錄對應多條從表記錄,一條從表記錄對應多條主表記錄。

關系型數據庫管理系統(DBMS):

     關系型數據庫只是一個保存數據的容器,大多數數據庫依靠一個稱為數據庫管理系統(DBMS)的軟件來管理數據庫中的數據。

     目前流行的關系型數據庫服務器管理系統有:

      ① 微軟的MS SQL Server

      ② 甲骨文的Oracle

      ③ IBM公司的DB2

      ④ 開源數據庫的MySQL、PostgreSQL

SQL:

     SQL是結構化查詢語言,是一種用于管理關系型數據庫,并與數據庫中的數據進行通訊的計算機語言。

SQL語句:

     ① 數據定義語言(DDL): 用于創建、修改和刪除數據庫內的數據結構。

-- 創建數據庫db
CREATE DATABASE db;
-- 刪除數據庫db
DROP DATABASE db;
-- 建立表t_student
CREATE TABLE t_student(
 -- PRIMARY KEY標志該列為主鍵列
 -- AUTO_INCREMENT設置自動增長列,該列的值由DBMS分配,不用開發者維護
 id INT PRIMARY KEY AUTO_INCREMENT,-- 編號
 studentName VARCHAR(20),-- 姓名,20表示名字20個字
 sex ENUM('男','女'),-- 性別,enum表示枚舉
 birthday DATE, -- 生日
 tel VARCHAR(11) -- 電話
);

 ② 數據查詢語言(DQL):用于數據庫中數據的查詢 

-- 查詢所有的性別 DISTINCT表示去除重復的列

SELECT DISTINCT sex FROM t_student;

-- 查詢表中所有的數據,*表示查詢表中所有的列
SELECT * FROM t_student;

-- 查詢第一條 開始的數據,顯示3條記錄
SELECT * FROM t_student LIMIT 0,3;

③ 數據操作語言(DML): 用于修改數據庫中的數據,包括插入、更新和刪除數據

-- 添加記錄
INSERT INTO t_student(studentName,sex,birthday,tel)
VALUES('張三','男','1983-09-30','13987879898');

-- 刪除id為17的記錄
DELETE FROM t_student WHERE id=17;

-- 修改李四的電話
UPDATE t_student SET tel='13966666666' WHERE studentName='李四';

④ 數據控制語言(DCL):控制數據庫訪問權限

-- 給用戶授予訪問權限的GRANT語句

 -- 取消用戶訪問權限的REVOKE語句

 外鍵約束:

       外鍵:是指從表的某列與主鍵的某列存在依附關系。

        外鍵約束:是指在外鍵關聯主鍵上強制加上一個約束,如果違反該約束,則不允許該條數據的修改。

        注意:沒有建立外鍵約束不等于沒有外鍵。

主鍵約束:

        主鍵是表中的一到多個列,主鍵列不能為空,也不能重復,一個表中只能由一個主鍵。

聚合函數:

      對一組數據進行統計分析是使用聚合函數來實現的。常見聚合函數如下:

       COUNT:統計行數量。

       SUM:獲取單個列的和計量。

       AVG:計算某個列的平均值。

       MAX:計算某個列的最大值。

       MIN:計算某個列的最小值。

SQL語句的執行順序:

      第一步:執行FROM

       第二步:where條件過濾

       第三步:GROUP BY分組

       第四步:執行select投影列

       第五步:HAVING條件過濾

       第六步:執行ORDER BY排序語句,默認為asc升序,DESC為降序。

聯接:

      內聯接和外聯接的區別:

       內聯接:只能查詢兩個表中都有的相關數據的記錄;

       外連接:可以查詢一個表中所有的記錄,無論該記錄是否有關聯數據。

 

CREATE TABLE t_man(
 id INT PRIMARY KEY AUTO_INCREMENT,
 manName VARCHAR(20),
 birthday DATE
);
INSERT INTO t_man(manName,birthday)
VALUES('張三','1980-02-03'),('李四','1994-01-05'),
  ('王五','1991-07-30'),('趙六','1995-11-18');
SELECT * FROM t_man;
 
 CREATE TABLE t_bike(
 id INT PRIMARY KEY AUTO_INCREMENT,
 bikeType VARCHAR(20),
 money INT,
 manId INT
 );
 
 -- 添加外鍵約束,讓主鍵和外鍵一一對應,防止垃圾數據的產生
 ALTER TABLE t_bike ADD CONSTRAINT fk_mb FOREIGN KEY (manId)
 REFERENCES t_man(id);
 
 INSERT INTO t_bike(bikeType,money,manId)
 VALUES('鳳凰',400,1),('永久',500,1),('火麒麟',250,1),
  ('大運',1000,2),('夏力',600,2),('捷安特',1200,3),
  ('摩拜',200,3),('寶馬',2000,3),('奔馳',600,3);
 
 -- 查詢所有自行車,并顯示該自行車的主人姓名
 SELECT b.*,m.manName FROM t_bike b JOIN t_man m ON m.id=b.manId;
 
 -- 查詢李四所有的自行車(內連接:顯示兩個表中有聯系的數據)
 SELECT b.* ,m.manName FROM t_bike b JOIN t_man m ON m.id=b.manId WHERE m.manName='李四';
 SELECT b.* ,m.manName FROM t_man m JOIN t_bike b ON m.id=b.manId WHERE m.manName='李四';
 
 SELECT b.* FROM t_bike b,t_man m WHERE b.manId=m.id AND m.manName='李四';
 
 -- 顯示所有用戶的自行車信息,外連接不能用,加where的形式來寫
 -- 外連接:RIGHT 右外連接,包含右邊表中所有的信息,left 左外連接,包含左邊表中所有的信息。 
 SELECT m.*,b.bikeType,b.money FROM t_bike b RIGHT JOIN t_man m ON b.manId=m.id;
 
 -- 顯示所有用戶自行車的數量
 -- 左外連接
 SELECT m.*,COUNT(bikeType) num FROM t_man m LEFT JOIN t_bike b ON m.id=b.manId GROUP BY m.id;
 -- 右外連接
 SELECT m.*, COUNT(bikeType) number FROM t_bike b RIGHT JOIN t_man m ON b.manId=m.id GROUP BY m.id;

希望本篇文章對您有所幫助

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

黔江区| 海口市| 梁山县| 绵阳市| 六枝特区| 隆昌县| 玉山县| 杭锦后旗| 龙胜| 含山县| 民丰县| 仪征市| 庆阳市| 四子王旗| 米易县| 探索| 土默特右旗| 岑溪市| 那曲县| 清水县| 博乐市| 融水| 三台县| 赫章县| 灵武市| 涞水县| 秦安县| 南和县| 汕尾市| 泰安市| 莱州市| 阿拉善盟| 左权县| 西乡县| 肇庆市| 霍林郭勒市| 西乌珠穆沁旗| 澄江县| 青龙| 汝州市| 元朗区|