MYSQL学习整理|高级SQL语句

MYSQL的三种语言:

DDL DML DCL

DML(data manipulation language):

它们是SELECT、UPDATE、INSERT、DELETE,就象它的名字一样,这4条命令是用来对数据库里的数据进行操作的语言

DDL(data definition language):

DDL比DML要多,主要的命令有CREATE、ALTER、DROP等,DDL主要是用在定义或改变表(TABLE)的结构,数据类型,表之间的链接和约束等初始化工作上,他们大多在建立表时使用

DCL(Data Control Language):

是数据库控制功能。是用来设置或更改数据库用户或角色权限的语句,包括(grant,deny,revoke等)语句。在默认状态下,只有sysadmin,dbcreator,db_owner或db_securityadmin等人员才有权力执行DCL

数据库模型:

概念模型,逻辑模型,物理模型 ER图
数据库设计的步骤:
需求分析,概念结构设计,逻辑结构设计,物理结构设计,数据库实施,数据库运行和维护
数据库的引擎决定了数据在数据库中的存储方式

数学函数:

ABS SUM AVG MAX MIN FLOOR(返回小于或等于x的最大整数) RAND TRUNCATE SQRT(平方根)
UPPER UCASE LEFT SUBSTRINGSORT COUNT ASCII CHAR
NOW YEAR CURDATE CURRENT_DATE CURTIME CURRENT_TIME LOCALTIME SYSDATE LOCALTIMESTAMP
ENCODE ENCRYPT IF IFNULL FORMAT CAST USER VERSION

关于整个数据库的操作:

CREATE ALTER DROP
SHOW DATABASE
SHOW TABLES FROM db_school

修改数据库:

ALTER TABLE … ADD … VARCHAR
e.g. ALTER TABLE … ADD COLUMN id INT NOT NULL UNIQUE AUTO_INCREMENT FIRST;
CHANGE 同时修改列名和数据类型
ALTER
MODIFY 只修改数据类型,不会干涉列名

主键外键的设计:

CONSTRAINT FK_student FOREIGN KEY (classNo) REFERENCES tb_class(classNo)
CONSTRAINT PK_student ORIMARY KEY(studentNo)
DROP FOREIGN KEY
DROP PRIMARY KEY
DROP INDEX KEY
ALTER TABLE ADD … CONSTRAINT …

使用SELECT FROM WHERE可能用到的其他关键字:

NOT
IN
NOT IN
LIKE ‘王%’
IS NULL
AND OR
ORDER BY
GROUP BY…HAVING

数据更新:

INSERT INTO … VALUES …
REPLACE INTO … VALUES…
UPDATE …SET … WHERE…
DELETE FROM… WHERE…
TRUNCATE

查询修改索引:

SHOW INDEX FROM …
CREATE TABLE … INDEX(studentname)
CREATE INDEX index_stu ON db.tb(studentNo)
ALTER TABLE … ADD INDEX …
DROP INDEX … ON …

视图:

作用:集中分散的data,简化查询语句,重用SQL语句,保护DATA SAFE,共享所需数据,更改数据样式
创建视图不能再FROM字句中使用子查询
视图不可以添加索引,触发器,默认值

视图的相关操作:

创建视图:
CREATE OR REPLACE VIEW db.v AS
SELECT * FROM db.tb WHERE …
WITH CHECK OPTION;
删除视图:
DROP VIEW IF EXISTS db.v
修改视图:
ALTER VIEW db.v AS
SELECT * FROM db.tb WHERE …
WITH CHECK OPTION;
INSERT INTO db.v VALUES ();
SELECT …FROM db.v
UPDAPTE db.v SET …
DELETE FROM … WHERE

触发器相关:

CREATE TRIGGER db.tbtrigger AFTER INSERT
ON db.tb FOR EACH ROW SET @str=’one student added’// SET NEW.nation= OLD.native
DROP TRIGGER IF EXISTS …

事件相关:

DELIMITER $$
CREATE EVENT IF NOT EXISTS event_insert
ON SCHEDULE EVERY 1 MONTH
STARTS CURDATE()+INTERVAL 1 MONTH
ENDS ‘2016-12-31’
DO
BEGIN
IF YEAR(CURDATE())<2013 THEN
INSERT INTO tb_student
VALUES();
END IF;
END $$

ALTER EVENT event_insert DISABLE;
ALTER EVENT event_insert ENABLE;
ALTER EVENT event_insert RENAME TO e_insert;
DROP EVENT IF EXISTS event_name;

存储过程相关:

增强SQL功能和灵活性,封装,高性能,减少网络流量,作为一种安全机制
SHOW PROCEDUCE STATUS 查看数据库中存在哪些存储过程
DROP PROCEDUCE FUNCTION IF EXISTS sp_name

DELIMITER $$
CREATE PROCEDUCE sp_update_sex(IN sno CHAR(20),IN ssex CHAR(2))
BEGIN
UPDATE tb SET sex=ssex WHERE studentNo = sno;
END $$

存储函数:

USE DB_SCHOOL
DELIMITER $$
CREATE FUNCTION fn_search (sno CHAR(10))
RETURNS CHAR(2)
DETERMINISTIC
BEGIN
DECLARE SSEX CHAR(2);
SELECT sex INTO SSEX FROM tb_student
WHERE studentNo = sno;
IF SSEX IS NULL THEN
RETURN (SELECT ‘没有该生’);
ELSE IF SSEX = ‘女’THEN
RETURN (SELECT ‘女’);
ELSE RETURN (SELECT ‘男’);
END IF;
END IF;
END $$

SELECT fn_search(‘2013210101’)
DROP FUNCTION IF EXISTS fn_search

游标相关:

DECLARE cursor_name CURSOR FOR (SELECT语句)
OPEN cursor_name
FETCH cursor_name INTO var_name
CLOSE cursor_name

访问控制和安全管理:

SELECT PASSWORD(‘456’)
CREATE USER ‘zhangsan’@’localhost’
INENTIFIED BY ‘123’;

DROP USER zhangsan@ localhost;
RENAME USER … TO …
SET PASSWORD FOR ‘wangwu’@‘localhost’=’xxxxxxxx’;
账户权限:
SHOW GRANTS FOR ‘zhangsan’@’localhost’
GRANT SELECT,UPDATE
ON db.tb
TO ‘liming’@‘localhost’ INENTIFIED BY ‘123’;

GRANT ALL ON … TO …;
回收权限:
REVOKE SELECT
ON db.tb
FROM ‘liming’@‘localhost’;

备份和恢复:

SELECT * FROM db.tb
INTO OUTFILE ‘c:\backup\backupfile,txt’
FIELDS TERMINATED BY’,’
OPTIONALLY ENCLOSED BY ‘”’
LINES TERMINATED BY ‘?’;

LOAD DATA INFILE …
INTO TABLE …
FIELDS TERMINATED BY’,’
OPTIONALLY ENCLOSED BY ‘”’
LINES TERMINATED BY ‘?’;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容