SQL-結構化查詢語言(1)


一:數據查詢語言(DQL),Data Query Language,用以從表中獲取數據,確定數據怎樣在程序中給出。SELECT是DQL中用的最多的!
select user,host,password from mysql.user order by user asc;
select user,host,password from mysql.user order by user desc;
二:數據操作語言(DML),Data Manipulation Language,包括INSERT, UPDATE和DELETE。
delete from mysql.user where user='myname';
三:事物處理語言(TPL),它的語句能確保被DML語句影響的表的所有行及時得更新。TPL語句包括BEGIN, TRANSACTION, COMMIT和ROLLBACK。
四:數據控制語言(DCL),DCL全稱是Data Control Language,包括GRANT或REVOKE。
五:數據定義語言(DDL),Data Definition Language,其語句包括create和DROP。
六:指針控制語言(CCL),DECLARE CURSOR,FETECH INTO等
最后可以總結為如下:

SQL常見操作
1:創建數據庫
create database myyang DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
show create database myyang;
2:查看當前使用的數據庫
select database();
select version();
select user();
select now();
3:刪除數據庫
drop database myyang;
4:進入數據庫
use myyang;
5:使用-e參數不進入數據庫執行命令
mysql -uroot -p123456 -e "show grants for myyang@localhost;" 
6:回收權限
REVOKE INSERT ON test.* FROM 'myyang'@'localhost';
7:MySQL的權限
     1	SELECT, 
     2	INSERT,
     3	UPDATE, 
     4	DELETE, 
     5	CREATE, 
     6	DROP, 
     7	REFERENCES, 
     8	INDEX, 
     9	ALTER, 
    10	CREATE TEMPORARY TABLES, 
    11	LOCK TABLES, 
    12	EXECUTE, 
    13	CREATE VIEW, 
    14	SHOW VIEW, 
    15	CREATE ROUTINE, 
    16	ALTER ROUTINE, 
    17	EVENT, 
    18	TRIGGER
8:建表示例
create table student(id int(4) not null, name char(20) not null, age tinyint(2) not null default '0', dept varchar(16) default null) ENGINE=InnoDB DEFAULT CHARSET=utf8;

Markdown

索引
  • 主鍵索引
create table student2(
id int(4) not null AUTO_INCREMENT,
name char(20) not null,
age tinyint(2) NOT NULL 
dept varchar(16) default NULL,
primary key(id),
KEY index_name(name)
);
PS: primary key(id) 是主鍵
KEY index_name(name) name字段普通索引
alter table student2 drop primary key; 刪除主鍵
alter table student2 change id id int primary key auto_increment;
利用alter命令修改id列為自增主鍵
  • 普通索引
KEY index_name(name)
index_name 是索引的名字
name是創建普通索引的字段
alter table student2 drop index index_name;刪除索引
alter table student2 add index index_name(name);添加索引
對前n個字符簡歷索引
create index index_dept on student2(dept(8));
對dept列的前8個字符創建索引
show index form student2;
查看索引
對表的多個字段創建聯合索引
create index ind_name_dept on student2(name,dept);
ps:聯合索引允許列上有自己的索引
也可以使用drop來刪除索引
drop index ind_name_dept on student2;
對多個列的前n個字符創建索引
create index ind_name_dept on student(name(8),dept(10));
聯合索引是有前綴生效條件的
index(a,b,c)僅a,ab,abc三個查詢條件可以走索引,b,bc,ac,c等無法使用索引了
  • 唯一索引
創建唯一索引,插入的時候必須唯一,多用於郵箱注冊
create unique index uni_index_name on student(name);
索引列的創建及生效條件
  1. 索引占用系統空間,更新數據庫時需要維護索引數據,索引並不是越多越好,更新頻繁讀取較少的表要少建立索引
  2. 索引一定要創建在where后的條件列上,而不是select后選擇的數據列,盡量選擇在唯一值多的大表上建立索引
插入數據
create table test(id int(4) not null AUTO_INCREMENT,name varchar(20) not null, PRIMARY KEY(id));
1:指定所有列明然后給數據
insert into test(id,name) values(1,'ob');
2:由於主鍵是自增的,因此只需要給name列
insert into test(name) values('oc');
3:不指定列,必須按照列的對應一個一個給值,也不能省掉自增列
insert into test values(3,'od');
insert into test values(4,'oe'),(5,'of');
備份數據庫
mysqldump -uroot -p123456 -B test > /opt/test.sql
查看備份的sql語句
grep -E -v "#|\/|^$|--" /opt/test.sql
dump是邏輯備份,把sql的數據以sql的命令形式導出
查詢數據
select * from test;
select id,name from test;
ps:不建議用*
查詢兩個
select id,name from test limit 2;
select id,name from test limit 0,2;從0開始查查詢兩個
select id,name from test where id=1;
select id,name from test where name='od';字符串類型的查詢條件需要引號
select id,name from test where name='od' and id=3; and代表兩遍都要成立
select id,name from test where name='od' or id=5;or代表或
select id,name from test where id>2 and id<4;
select id,name from test order by id asc; asc是升序
select id,name from test order by id desc; desc是降序
連表查詢
1:創建學生表
mysql> create table student(
    -> Sno int(10) NOT NULL COMMENT '學號',
    -> Sname varchar(16) NOT NULL COMMENT '姓名',
    -> Ssex char(2) NOT NULL COMMENT '性別',
    -> Sage tinyint(2) NOT NULL default '0' COMMENT '學生年齡',
    -> Sdept varchar(16) default NULL COMMENT '學生所在系別',
    -> PRIMARY KEY (Sno),
    -> key index_Sname (Sname));
2:創建課程表
mysql> create table course(                                                      -> Cno int(10) NOT NULL COMMENT '課程號',
    -> Cname varchar(64) NOT NULL COMMENT '課程名',
    -> Ccredit tinyint(2) NOT NULL COMMENT '學分',
    -> PRIMARY KEY (Cno));
3:選課表
mysql> create table SC(
    -> SCid int(12) NOT NULL AUTO_INCREMENT COMMENT '主鍵',
    -> Cno int(10) NOT NULL COMMENT '課程號',
    -> Sno int(10) NOT NULL COMMENT '學號',
    -> Grade tinyint(2) NOT NULL COMMENT '學生成績',
    -> PRIMARY KEY (Scid));
4:插入數據
insert into student values(0001,'趙信','男',30,'計算機網絡');
insert into student values(0002,'蓋倫','男',30,'Python');
insert into student values(0003,'孫悟空','男',30,'Java');
insert into student values(0004,'亞索','男',30,'Go');
insert into student values(0005,'提莫','女',6,'.net');
insert into student values(0006,'金克斯','女',6,'shell');

insert into course values(1001,'Linux運維',3);
insert into course values(1002,'Python開發',5);
insert into course values(1003,'Java開發',4);
insert into course values(1004,'.NET開發',4);
insert into course values(1005,'Go開發',4);
insert into course values(1006,'shell開發',3);

insert into SC(Sno,Cno,Grade) values(0005,1004,9);
insert into SC(Sno,Cno,Grade) values(0004,1003,6);
insert into SC(Sno,Cno,Grade) values(0003,1002,1);
insert into SC(Sno,Cno,Grade) values(0002,1001,3);
insert into SC(Sno,Cno,Grade) values(0001,1005,6);
insert into SC(Sno,Cno,Grade) values(0006,1006,6);

5:連表查詢
select student.Sno,student.Sname,course.Cname,SC.Grade from student,course,SC where student.Sno=SC.Sno and course.Cno=SC.Cno order by Sno;


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM