修改表 修改表 語法: Alter table <舊表名> rename [ TO] <新表名>; 例子:Alter table `demo01` rename `demo02`; 添加欄位 語法: Alter Table 表名 ADD 欄位名 數據類型 [屬性]; 例子:Alter Table ` ...
修改表
修改表
語法:
Alter table <舊表名> rename [ TO] <新表名>;
例子:Alter table `demo01` rename `demo02`;
添加欄位
語法:
Alter Table 表名 ADD 欄位名 數據類型 [屬性];
例子:Alter Table `Demo02` ADD `passWord` varchar(50) not null;
修改欄位
語法:
Alter table 表名 change 原欄位名 新欄位名 數據類型 [屬性];
%修改欄位名%
Alter Table `Demo02` change `name` `username` char(10) NOT NULL;
刪除欄位
刪除欄位是將數據表中的某個欄位從表中移除:
語法: ALTER TABLE 表名 DROP 欄位名;
添加主外鍵
1.添加主鍵約束
語法: ALTER TABLE 表名 ADD CONSTRAINT 主鍵名 PRIMARY KEY 表名(主鍵欄位);
2.添加外鍵約束
語法: ALTER TABLE 表名 ADD CONSTRAINT 外鍵名 FOREIGN KEY (外鍵欄位) REFERENCES 關 聯表名(關聯欄位);
DML語句回顧
插入數據記錄
1.插入單行數據
語法: INSERT INTO 表名 [(欄位名列表)] VALUES (值列表);
2.插入多行數據
語法:INSERT INTO 新表 (欄位名列表) VALUES (值列表1), (值列表2), ......, (值列表n);
註意:在是INSERT語句插入記錄時,如果不包含欄位名稱,VALUES後值列表中各欄位的順序必須和表定義中各欄位的順序相同,如果表結構變了 (如執行了添加數據操作) 則值列表也要變化,否則會出現錯誤.如果指定了插入的欄位名,就會避免這個問題,因此,建議在插入數據時指定具體欄位名.
3.將查詢結構插入到新表
語法1:
INSERT INTO 新表(欄位1,欄位2,......)
SELECT 欄位1,欄位2,......
FROM 原表;
語法2:
CREATE TABLE 新表 (SELECT 欄位1,欄位2, ........FROM 原表);
更新數據記錄
語法: UPDATE 表名 SET 欄位1=值1,欄位2=值2,........欄位n=值n [WHERE 條件];
刪除數據記錄
語法: DELETE FROM 表名 [WHERE條件];
語法: TRUNCATE TABLE 表名;
數據查詢
DQL語句回顧
SQL Server中數據查詢語句:
語法: SELECT<欄位名列表>
FROM<表名或視圖>
[WHERE <查詢條件>]
[GROUP BY <分組的欄位名>]
[HAVING <條件>]
[ORDER BY <排序的欄位名> [ASC 或 DESC]];
LIMIT子句
語法: SELECT<欄位名列表>
FROM<表名或視圖>
[WHERE <查詢條件>]
[GROUP BY <分組的欄位名>]
[ORDER BY <排序的欄位名> [ASC 或 DESC]]
[LIMIT [位置偏移量, ]行數];
其中:1.位置偏移量指從結果集中第幾條數據開始顯示(第一條記錄的位置偏移量是0,第2條 是1,....),當省略時從第一條記錄開始顯示.
2.行數值顯示記錄的條數
常用函數
常用聚合函數:
AVG() |
返回某欄位的平均值 |
COUNT() |
返回某欄位的行數 |
MAX() |
返回某欄位的最大值 |
MIN( ) |
返回某欄位的最小值 |
SUM( ) |
返回某欄位的和 |
函數名 |
作用 |
常用的字元串函數
函數名 |
作用 |
舉例 |
CONCAT(str1,str2,...,strn) |
連接字元串str1,str2,...,strn為一個完整字元串 |
SELECT CONCAT(‘My’,’S’,’QL’); 返回:MySQL |
INSERT(str,pos,len,newstr) |
將字元串str從pos位置開始,len個字元長的子串替換為字元串newstr |
SELECT INSERT(‘這是SQL SERVER資料庫’,3,10,’MySQL’); 返回:這是MySQL資料庫 |
LOWER(str) |
將字元串str中所有字元變為小寫 |
|
UPPER(str) |
將字元串str中所有字元串變為大寫 |
SELECT UPPER(‘MySQL’); 返回: MYSQL |
SUBSTRING(str,num,len) |
返回字元串str的第num個位置開始長度為len的子字元串 |
|
3.時間日期函數
函數名 |
作用 |
舉例 |
CURDATE() |
獲取當前日期 |
SELECT CURDATE(); |
CURTIME() |
獲取當前時間 |
|
NOW() |
獲取當前日期和時間 |
|
WEEK(date) |
返回日期date為一年的第幾周 |
|
YEAR(date) |
返回日期date的年份 |
|
HOUR(time) |
返回時間Time的小時值 |
|
MINUTE(time) |
返回時間Time的分鐘值 |
|
DATEDIFF(date1,date2) |
返回日期參數date1和date2之間相隔的天數 |
|
ADDDATE(date,n) |
計算日期參數date加上n天後的日期 |
|
4.數字函數
函數名 |
作用 |
舉例 |
CEIL(x) |
返回大於或等於數值x的最小整數 |
SELECT CEIL(2.3) 返回:3 |
FLOOR(x) |
返回小於或等於數值x的最大整數 |
|
RAND() |
返回0~1間的隨機數 |
|
子查詢
簡單子查詢
語法:SELECT ...FROM 表1 WHERE 欄位1 比較運算符(子查詢);
使用AS關鍵字,符合ANSI標準
SELECT 欄位列表 FROM 表名 AS 表的別名;
使用空格,簡便的方法
SELECT 欄位列表 FROM 表名 表的別名;
IN和NOT IN 子查詢
IN子查詢
使用子查詢 當返回結果有多條記錄時,則把條件的 =改為 in
IN子查詢後面可跟隨返回多條記錄的子查詢,用於檢測某欄位的值是否存在於某個範圍中.
NOT IN子查詢
不在IN子查詢範圍內的其他數據.