MySQL分類及基礎(chǔ)語句
SQL分類:
DDL類型。
包括數(shù)據(jù)庫、表的創(chuàng)建,修改,刪除,聲明—數(shù)據(jù)定義語言(CREATE,ALTER,DROP,DECLARE)
DML類型。
包括數(shù)據(jù)表中記錄的查詢,刪除,修改,插入—數(shù)據(jù)操縱語言(SELECT,DELETE,UPDATE,INSERT)
DCL類型。
包括數(shù)據(jù)庫用戶賦權(quán),廢除用戶訪問權(quán)限, 提交當前事務(wù),中止當前事務(wù)—數(shù)據(jù)控制語言(GRANT,REVOKE,COMMIT,ROLLBACK)
SQL基礎(chǔ)語句:
1、創(chuàng)建數(shù)據(jù)庫。
CREATE DATABASE db1(db1代表數(shù)據(jù)庫表,可自命名)
2、刪除數(shù)據(jù)庫。
drop database db1(db1代表數(shù)據(jù)庫表,可自命名)
3、備份sql server。
--- 創(chuàng)建 備份數(shù)據(jù)的 device
USE master
EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat'
--- 開始 備份
BACKUP DATABASE pubs TO testBack
4、創(chuàng)建新表。
create table tb1(Id int not null primary key,name varchar,..)(tb1為數(shù)據(jù)表名,ID為字段,int為數(shù)據(jù)類型整型,not null為數(shù)據(jù)是否可為空,Primary Key為主鍵設(shè)置,其中not null,primary key為可選項,字段,數(shù)據(jù)類型自定義。)
根據(jù)已有的表創(chuàng)建新表:
A:create table tab_new like tab_old (使用舊表創(chuàng)建新表)
B:create table tab_new as select col1,col2… from tab_old definition
5、刪除新表。drop table tb1
6、增加一個列。Alter table tabname add column col type
注:列增加后將不能刪除。DB2中列加上后數(shù)據(jù)類型也不能改變,唯一能改變的是增加varchar類型的長度。
7、添加主鍵。Alter table tabname add primary key(ID)(設(shè)置某字段為主鍵,ID可自由設(shè)置,主鍵數(shù)據(jù)不可重復(fù))
刪除主鍵。Alter table tabname drop primary key(ID)(刪除某字段主鍵)
//設(shè)置主鍵自增初始值:alter table tb auto_increment = 1;
8、創(chuàng)建索引。create [unique] index idxname on tabname(col….)
刪除索引。drop index idxname
注:索引是不可更改的,想更改必須刪除重新建。
9、創(chuàng)建視圖。create view viewname as select statement
刪除視圖。drop view viewname
10、幾個簡單的基本的sql語句
選擇:select * from table1 where Id=1(Id=1為條件語句,根據(jù)自己情況自定義)
插入:insert into table1(field1,field2) values(value1,value2)
刪除:delete from table1 where 范圍
更新:update table1 set field1=value1 where 范圍
查找:select * from table1 where field1 like ’%value1%’ ---like的語法很精妙,查資料!
排序:select * from table1 order by field1,field2 [desc]
總數(shù):select count * as totalcount from table1
求和:select sum(field1) as sumvalue from table1
平均:select avg(field1) as avgvalue from table1
最大:select max(field1) as maxvalue from table1
最?。簊elect min(field1) as minvalue from table1
11、幾個高級查詢運算詞
A: UNION 運算符
UNION 運算符通過組合其他兩個結(jié)果表(例如 TABLE1 和 TABLE2)并消去表中任何重復(fù)行而派生出一個結(jié)果表。當 ALL 隨 UNION 一起使用時(即 UNION ALL),不消除重復(fù)行。兩種情況下,派生表的每一行不是來自 TABLE1 就是來自 TABLE2。
B: EXCEPT 運算符
EXCEPT 運算符通過包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重復(fù)行而派生出一個結(jié)果表。當 ALL 隨 EXCEPT 一起使用時 (EXCEPT ALL),不消除重復(fù)行。
C: INTERSECT 運算符
INTERSECT 運算符通過只包括 TABLE1 和 TABLE2 中都有的行并消除所有重復(fù)行而派生出一個結(jié)果表。當 ALL 隨 INTERSECT 一起使用時 (INTERSECT ALL),不消除重復(fù)行。
注:使用運算詞的幾個查詢結(jié)果行必須是一致的。
12、使用外連接
A、left outer join:左外連接(左連接):結(jié)果集幾包括連接表的匹配行,也包括左連接表的所有行。
SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c
B:right outer join:右外連接(右連接):結(jié)果集既包括連接表的匹配連接行,也包括右連接表的所有行。
C:full outer join:全外連接:不僅包括符號連接表的匹配行,還包括兩個連接表中的所有記錄。