首页 > 数据库 >Mysql基础语法理论大全

Mysql基础语法理论大全

时间:2023-10-26 12:07:45浏览次数:56  
标签:-- 语法 索引 emp Mysql TABLE WHERE SELECT 大全


------------------------------------------------------------------------------------------------
第一章:SQL语言基础(SQL结构化查询语句)
------------------------------------------------------------------------------------------------
-- 按照SQL92、99标准 分为4大类
1:数据操作语言(DML) SELECT 查询,INSERT 插入,UPDATE 更新,DELETE 删除, 
2:数据定义语言(DDL) CREATE 创建,ALTER修改结构,DROP 删除 ,TRUNCATE 删除 等语句
3:事务处理语言(TCL) COMMIT 提交,ROLLBACK 回滚事务 等语句
4:数据控制语言(DCL) GRANT 授权,REVOKE 解除授权, 

说明:也可以把SELECT 作为数据操作语言(DQL)

-- SQL语句的语法规范
 1. SQL语句的所有表名、字段名全部小写,系统保留字、内置函数名、SQL保留字大写。
 2. 连接符OR、IN、AND、以及=、<=、>=等前后加上一个空格。
 3. 对较为复杂的SQL语句、存储过程、函数加上注释,说明算法、功能。
-- 单行注释
/*
多行注释
*/ 
 4. SQL语句的缩进风格
 1) 一行有多列,超过80个字符时,基于列对齐原则,采用下行缩进 
 2) WHERE子句书写时,每个条件占一行,语句另起一行时,以保留字或者连接符开始,连接符右对齐。 
 5. 多表连接时,使用表的别名来引用列。

-- 其他注意事项
1. SQL 命令大小写不敏感
2. SQL 命令可写成一行或多行
3. 一个关键字不能跨多行或缩写
4. 子句通常位于独立行,以便编辑,并易读 
5. SQL语句用分号作为分隔符,系统读取到分号才会执行语句

------------------------------------------------------------------------------------------------
第二章:表管理DDL语句
------------------------------------------------------------------------------------------------
数据定义语言(DDL) CREATE 创建,ALTER修改结构,DROP 删除 ,TRUNCATE 删除 等语句

1.新建表
CREATE TABLE 表名
(
列名1 数据类型 [DEFAULT 默认值][列级约束1,列级约束2 ……],
列名2 数据类型 [DEFAULT 默认值][列级约束1,列级约束2 ……],
...,
列名n 数据类型 [DEFAULT 默认值][列级约束1,列级约束2 ……],
[CONSTRAINT 约束名称 约束类型(列名)],
[CONSTRAINT 约束名称 约束类型(列名)],
...
);

-- 表名的命名规则
1)必须以字母开头
2)可包括数字
3)只能包含A-Z, a-z, 0-9, _, $, AND #
4)不要使用MySQL的保留字
5)同一用户的表对象不能同名

-- 数据类型
CHAR(10): 定长字符串    输入LUCY ,结果将占有10个字符
VARCHAR(10):变长字符串  输入LUCY,结果将占有4个字符

CREATE TABLE student
(
学号 INT(5),
姓名 VARCHAR(20),
年龄 TINYINT(2),
性别 CHAR(1),
系名 VARCHAR(10),
身份证号 VARCHAR(18),
专业号 INT(4)
)
CHARACTER SET = utf8; -- 创建表时数据支持中文字符样式

SELECT * FROM student;-- 查看表数据
DESC student; -- 查看表结构

-- 插入一条数据
INSERT INTO student
VALUES(20204,'王小明',19,'女','经济系','510839199810106670',1001);

INSERT INTO student(学号,姓名,系名)
VALUES(20305,'黄大鹏','管理系');

INSERT INTO student
VALUES
(20506,'张文斌',18,'女','外语系','510639199905183452',1005),
(20507,'张文',18,'男','外语系','510639199905183433',1005),
(20508,'张文',19,'男','外语系','510639199905183499',1005);

2:修改表结构
-- 不推荐在建表完成后去修改表结构,特别是表中已经有数据的情况
-- 修改默认值
ALTER TABLE 表名 ALTER COLUMN 列名 SET DEFAULT 默认值;
-- 删除默认值
ALTER TABLE 表名 ALTER COLUMN 列名 DROP DEFAULT 默认值;

ALTER TABLE student ALTER COLUMN 性别 SET DEFAULT '女';

INSERT INTO student(学号,姓名,系名)
VALUES(20601,'黄小明','表演系');

SELECT * FROM student;

-- 添加/删除列
ALTER TABLE 表名 ADD 列名 数据类型;
ALTER TABLE 表名 DROP 列名;

ALTER TABLE student  ADD 联系电话 VARCHAR(11);
ALTER TABLE student  DROP 联系电话;

-- 修改列名
ALTER TABLE 表名 CHANGE COLUMN 旧列名 新列名 新列的数据类型;-- 添加/修改列
ALTER TABLE 表名 MODIFY COLUMN 列名 数据类型;-- 修改数据类型

ALTER TABLE student CHANGE COLUMN 系名 院系名 VARCHAR(20);
ALTER TABLE student MODIFY COLUMN 姓名 VARCHAR(40);
DESC student;

3: 删除表
TRUNCATE TABLE 表名;-- 删除表中所有的数据,不能删除部分数据,全部删除
DROP TABLE 表名;--  删除整张表结构,含数据

TRUNCATE TABLE student;
SELECT * FROM student;
DROP TABLE student;

------------------------------------------------------------------------------------------------
第三章:表的约束
------------------------------------------------------------------------------------------------
-- 约束的种类
DEFAULT -- 默认值
PRIMARY KEY -- 主键约束
FOREIGN KEY -- 外键约束
NOT NULL -- 非空约束
UNIQUE -- 唯一约束
AUTO_INCREMENT  -- 自增约束

1:在创建表时增加约束
CREATE TABLE student2
(
学号 INT(5) PRIMARY KEY,
姓名 VARCHAR(20) NOT NULL,
年龄 TINYINT(2) DEFAULT 18,
性别 ENUM('男','女') NOT NULL  DEFAULT '女',
系名 VARCHAR(10),
身份证号 VARCHAR(18),
专业号 INT(4)
)
CHARACTER SET = utf8;

SELECT * FROM student2;
DESC student2;

-- 创建course表
CREATE TABLE course
(
专业号 INT(5) PRIMARY KEY AUTO_INCREMENT,
专业名称 VARCHAR(20) NOT NULL
)
CHARACTER SET = utf8;

SELECT * FROM course;

2:建表后增加约束(不推荐)
-- AUTO_INCREMENT默认从1开始自增,可以通过赋值改变初始值
ALTER TABLE  course AUTO_INCREMENT = 1001;
INSERT INTO  course(专业名称)
VALUES ('金融学');
INSERT INTO  course(专业名称)
VALUES ('国际金融与贸易');

-- 为student2表添加一个非空约束
ALTER TABLE 表名  MODIFY  列名 数据类型 NOT NULL;
ALTER TABLE student2 MODIFY 系名 VARCHAR(10) NOT NULL;
DESC student2

-- 为student2表添加一个唯一约束
ALTER TABLE 表名  ADD UNIQUE(列名);
ALTER TABLE student2  ADD UNIQUE(身份证号);

INSERT INTO student2
VALUES(20204,'王小明',19,'女','经济系','510839199810106670',1001);

INSERT INTO student2
VALUES(20205,'王小明',19,'女','经济系','510839199810106670',1001);

INSERT INTO student2
VALUES(20205,'王小明',19,'女','经济系','510839199810106671',1001);

INSERT INTO student2
VALUES(20205,NULL,19,'女','经济系','510839199810106671',1001);

SELECT * FROM student2;

-- 为student2表中的专业号设置外键约束
ALTER TABLE 从表名 ADD CONSTRAINT 外键名
FOREIGN KEY(从表的外键字段) REFERENCES 主表(主键字段);--  student2 表是从 ,course表是主表

ALTER TABLE student2 ADD CONSTRAINT FK_student2_course
FOREIGN KEY(专业号) REFERENCES course(专业号);

DESC student2
-- 查看表中的各种约束条件
SELECT * FROM information_schema.TABLE_CONSTRAINTS
WHERE constraint_schema = 'studentinfo2';

-- 查看创建的表的整体结构
SHOW CREATE TABLE 表名;
SHOW CREATE TABLE student2;
CREATE TABLE `student2` (
  `学号` INT(5) NOT NULL,
  `姓名` VARCHAR(20) NOT NULL,
  `年龄` TINYINT(2) DEFAULT '18',
  `性别` ENUM('男','女') NOT NULL DEFAULT '女',
  `系名` VARCHAR(10) NOT NULL,
  `身份证号` VARCHAR(18) DEFAULT NULL,
  `专业号` INT(4) DEFAULT NULL,
  PRIMARY KEY (`学号`),
  UNIQUE KEY `身份证号` (`身份证号`),
  KEY `FK_student2_course` (`专业号`),
  CONSTRAINT `FK_student2_course` FOREIGN KEY (`专业号`) REFERENCES `course` (`专业号`)
) ENGINE=INNODB DEFAULT CHARSET=utf8

------------------------------------------------------------------------------------------------
第四章:表的操作(DML语句)
------------------------------------------------------------------------------------------------
1:INSERT 插入
-- 全量数据插入,插入的数据,顺序必须和建表时的顺序一致
INSERT INTO 表名
VALUES(value1,value2...valueN);
-- 按照自定义的列进行数据的插入
INSERT INTO 表名(列名1,列名2,列名3...列名N)
VALUES(value1,value2...valueN);
-- 批量插入数据,插入的数据,顺序必须和建表时的顺序一致
INSERT INTO 表名
VALUES
(value1,value2...valueN),
(value1,value2...valueN),
(value1,value2...valueN);

SELECT * FROM dept;
-- 要求在部门表中插入一条记录
INSERT INTO dept
VALUES(50,'DEVELOPMENT','BEIJING');
-- dept表按指定列再次插入一行数据
INSERT INTO dept(deptno,dname)
VALUES(60,'MIS');
-- 注意空值的处理
INSERT INTO dept
VALUES(70,'TESTTEAM',NULL);
///
【扩展】事务TCL 
COMMIT 提交,ROLLBACK 回滚 SAVEPOINT  设置回滚点
Q;什么是事务?
-- 包含SQL语句的一个执行整体,对DML操作语句生效(对其他操作语句无效)
-- MySQL默认自动提交事务,可以通过命令来修改默认值
SET autocommit = 0; 表示手动提交事务,=1则表示自动提交事务(默认值)

-- 实际应用场景
ATM转账   A卡向B卡转账,结果A卡扣款成功,B卡到账失败  ——回滚A卡的数据
电商订单  确认订单后,商品库存被扣减,如果下订单失败,则商品库存需要回滚到下订单之前
-- 在emp表中插入一条记录

INSERT INTO employees.emp 
    (empno, 
    ename, 
    job, 
    mgr, 
    hiredate, 
    sal, 
    comm, 
    deptno
    )
    VALUES
    (6666, 
    'XIAOMING', 
    'DEVELOPMENT', 
    '7788', 
    CURDATE(), 
    '2000', 
    NULL, 
    50
    );

SELECT * FROM emp;

SAVEPOINT A;

INSERT INTO employees.emp 
    (empno, 
    ename, 
    job, 
    mgr, 
    hiredate, 
    sal, 
    comm, 
    deptno
    )
    VALUES
    (7777, 
    'XIAOMING', 
    'DEVELOPMENT', 
    '7788', 
    CURDATE(), 
    '2000', 
    NULL, 
    50
    );
-- 要求还原到上一组插入的数据,如何回滚?
ROLLBACK TO SAVEPOINT A;
SELECT * FROM emp;

ROLLBACK ;  -- 直接回滚则是回滚到最初设置事务的位置
SELECT * FROM emp;
-- 事务一旦提交,则直接对数据库服务器中的数据生效,不能再次回滚
///
-- 从其他表中插入数据到当前表insert + select
-- 把有提成的员工信息,导入到bonus表中
CREATE TABLE bonus
(
ename VARCHAR(10),
job VARCHAR(9),
sal FLOAT(7,2),
comm FLOAT(7,2)
)
SELECT * FROM bonus;

-- INSERT INTO 表名 SELECT 完整查询语句
INSERT INTO bonus
SELECT ename,job,sal,comm FROM emp 
WHERE comm IS NOT NULL;

DESC emp

2. UPDATE 修改
UPDATE 表名
SET 列名1=value1,列名2=value2....列名N=valueN
WHERE 限定条件

-- 调整dept表中50号部门的地址
UPDATE dept
SET loc='CHENGDU' WHERE deptno = 50;
SELECT * FROM dept

-- 想要给emp表中所有员工+200元 其中KING不加薪水
UPDATE emp
SET sal=sal+200 WHERE ename <> 'KING';
SELECT * FROM emp;

-- UPDATE语句中的set和where后面都可以使用子查询语句,但不能是对同一张表的操作
-- 将所有工资比ALLEN高的员工,薪水改成和ALLEN一样
-- 错误案例
UPDATE emp 
SET sal = (SELECT sal FROM emp WHERE ename = 'ALLEN') 
WHERE sal > (SELECT sal FROM emp WHERE ename = 'ALLEN');

UPDATE emp d,(SELECT e.sal FROM emp e WHERE e.ename='ALLEN') a SET d.sal = a.sal
WHERE d.sal >a.sal;

-- 将RESEARCH部门所有员工的上级改为King
UPDATE emp
SET mgr = (SELECT empno FROM (SELECT empno FROM emp WHERE ename='KING') a)
WHERE deptno= (SELECT deptno FROM dept WHERE dname= 'RESEARCH')
-- 另一种解法
UPDATE emp e,dept d SET mgr = 7902 WHERE e.deptno=d.deptno
AND d.dname='research';

SELECT * FROM emp WHERE deptno=20 

ROLLBACK;

3. DELETE 删除
DELETE [FROM] 表名
WHERE 限定条件 -- 如果delete不加where条件,则表示删除表中的所有数据

SELECT * FROM bonus;
DELETE FROM bonus;
COMMIT;

-- 删除dept表中50,60,70号部门
DELETE FROM dept WHERE deptno IN(50,60,70) ;
SELECT * FROM dept;
COMMIT;

-- 使用子查询删除数据
-- 删除sales部门的所有员工信息
DELETE FROM emp
WHERE deptno = (SELECT deptno FROM dept WHERE dname='SALES');
SELECT * FROM emp;
ROLLBACK;

注意:请先关闭自动提交事务功能 SET autocommit=0;
1.在EMP表中,增加一名员工,员工信息参照现有员工构造.

2.员工SMITH调动到SALES部门,请编写SQL语句更新员工信息.

3.员工JAMES已经离职,请编写SQL语句更新数据库.

4.用户执行DELETE FROM emp;语句删除了EMP表的记录,但没有提交,请问有办法恢复EMP原来的数据吗? 

------------------------------------------------------------------------------------------------
第五章 常用数据库对象
------------------------------------------------------------------------------------------------
1.视图
-- 视图是查询数据的快捷方式,视图不存储数据,存储的是一个查询语句
/*
CREATE VIEW 视图名称
(别名1,别名2,别名3...别名N)
AS
SELECT -- 一个完整的查询语句
*/
1)新建视图
【用法一】针对不同的用户,提供不同的权限(权限控制)
-- HR,BOSS 想要查看每个员工的薪水
SELECT empno,ename,sal FROM emp;

-- 20号部门的经理,要求只能查询自己部门的员工薪水
SELECT empno,ename,sal FROM emp WHERE deptno = 20;

CREATE VIEW v_dept20
AS
(SELECT * FROM emp WHERE deptno = 20);

SELECT * FROM v_dept20   -- 视图和表的用法相同
-- 对视图进行操作,为SMITH涨薪水 200
UPDATE v_dept20
SET sal=sal+200
WHERE ename='SMITH';

Q: 请问emp表SMITH的薪水是多少? -- 1000 修改视图的数据等于修改原表的数据 
SELECT empno,ename,sal FROM emp WHERE ename='SMITH'; 

【用法二】简化复杂的查询语句
-- 通过部门名称查询该部门的平均工资
SELECT AVG(e.sal)
FROM emp e,dept d
WHERE e.deptno=d.deptno
AND d.dname='SALES';

-- 视图
CREATE VIEW v_avgsal
AS
(SELECT e.*,d.dname,d.loc FROM emp e,dept d WHERE e.deptno=d.deptno);

SELECT * FROM v_avgsal;
SELECT AVG(sal) FROM v_avgsal WHERE dname='SALES'

2)删除视图
-- DROP VIEW 视图名称
DROP VIEW  v_dept20;  -- 删除视图,实际上只是删除了一个select语句,不会影响到原表的数据
DROP VIEW  v_avgsal;  
SELECT * FROM emp

2.索引 INDEX
Q:什么是索引?
-- 索引(INDEX)类似书的目录,是供服务器在表中快速查找和操作行的数据库结构
-- 索引是以列为单位建立的,经常作为查询条件的列,可以创建索引来提高查询效率

Q:索引设计原则
-- 经常出现在where,order by,group by后面的列可以创建索引
-- 有大量空值的列,数据频繁改动的列,不经常作为查询条件的列不要创建索引
-- 当某个数据具有唯一性特征时,可以指定唯一索引,以确保数据的完整性,提高查询速度

Q:优点
-- 可以大大提高数据的查询速度,这是建索引的主要原因
-- 索引的内部结构由系统自动创建,每次对数据的修改索引也会自动更新
-- 在创建主键约束和唯一约束时,会自动创建主键索引和唯一索引,保证每行数据的唯一性

Q:不足
-- 索引虽然提高了查询速度,同时却会降低更新表的速度,因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件。
-- 建立索引会占用磁盘空间的索引文件,每个表至少支持16个索引(依据存储引擎的不同而有所区别)

索引分类:普通索引和唯一索引
1)普通索引——允许在定义的索引列中插入重复的值/空值
-- 创建普通索引
CREATE INDEX 索引名称 ON 表名(列名(`length`)); -- 如果是BLOB,TEXT数据类型,必须制定length
-- 为ename字段创建索引
CREATE INDEX ind_ename ON emp(ename);
-- 添加索引
ALTER TABLE emp ADD INDEX ind_mgr(mgr);

-- 查看索引
SHOW INDEX FROM emp

-- 在建表时添加索引
CREATE TABLE  mytable
(
id INT PRIMARY KEY,
myname VARCHAR(20),
INDEX ind_myname(myname)
);

SELECT * FROM mytable;

2)唯一索引——索引的列数据必须唯一,但允许有空值NULL,如果是组合索引,则列值的组合必须唯一
-- 创建索引
CREATE UNIQUE INDEX 索引名称 ON 表名(列名(`length`));
-- 添加索引
ALTER TABLE 表名 ADD UNIQUE INDEX 索引名称(列名(`length`));
-- 在建表时添加索引
CREATE TABLE  mytable1
(
id INT PRIMARY KEY,
myname VARCHAR(20),
UNIQUE ind_myname(myname)
);

SHOW INDEX FROM mytable1

-- 当经常使用多个组合条件进行查询时使用组合索引
CREATE INDEX ind_job_deptno ON emp(job,deptno);
SHOW INDEX FROM emp
-- 如果查询条件只有job,该索引生效
-- 如果查询条件是job和deptno 该索引生效
-- 如果查询条件是deptno 该索引不生效

3) 删除索引
DROP  INDEX 索引名称 ON 表名;
DROP  INDEX ind_job_deptno ON emp;
DROP  INDEX ind_mgr ON emp;
DROP  INDEX ind_ename ON emp;

【注意】索引的限制条件
A.MyISAM存储引擎支持的索引引键长度不超过1000字节
B.MySQL目前不支持函数索引
C.使用!= ,<> 不能使用索引
SELECT * FROM emp
WHERE ename <> 'ALLEN';

SELECT * FROM emp
WHERE ename < 'ALLEN'
OR ename > 'ALLEN'

D. LIKE不能以%开头,无法使用索引

------------------------------------------------------------------------------------------------
第六章 存储过程  Stored PROCEDURE (SP)
------------------------------------------------------------------------------------------------
-- 简单来说,存储过程是一条或者多条SQL语句的集合
-- 存储过程能够实现较复杂的数据处理
-- MYSQL中的编程主要是在存储过程中实现的

-- 实际应用场景
-- 业务场景,部分业务逻辑被写入了SP中 举例:电商业务中,生成一张订单:插入数据到订单表;商品信息表修改商品数量,插入一条日志信息
-- 构建一整套测试数据  举例: 准备100个注册用户信息;准备N条日志测试翻页

DELIMITER //
CREATE PROCEDURE 存储过程名称(参数列表)
BEGIN 
程序主体;
END //
DELIMITER ;

-- DELIMITER //是告诉系统不要将分号作为分隔符,而是将//作为分隔符
-- DELIMITER ;是告诉系统请使用分号作为后续的分隔符

-- 参数列表
IN 参数名称 参数类型  -- 输入参数
OUT 参数名称 参数类型 -- 输出参数
INOUT 参数名称 参数类型 -- 也可以输入也可以输出的参数(不推荐)
-- 调用存储过程
CALL 存储过程名称(参数列表)
-----------------------------------------------------
-- 编写一个存储过程,输出 hello kitty
DELIMITER //
CREATE PROCEDURE pro_hello()
BEGIN 
SELECT "hello kitty";
END //
DELIMITER ;

CALL pro_hello();
-----------------------------------------------------
-- 编写一个带参数的存储过程
-- 输入一个员工编号,查询出该员工的薪水
DELIMITER //
CREATE PROCEDURE pro_empno(IN paramA INT)
BEGIN 
SELECT sal FROM emp
WHERE empno = paramA ;
END //
DELIMITER ;

CALL pro_empno(7839);

-----------------------------------------------------
-- 编写一个带参数的存储过程
-- 输入一个员工编号,返回其所在部门的平均工资
-- SELECT ... INTO... 给变量/参数赋值
DELIMITER //
CREATE PROCEDURE pro_empno_avgsal(IN paramA INT,OUT paramB FLOAT)
BEGIN 
SELECT AVG(sal) INTO paramB FROM emp
WHERE deptno =
(SELECT deptno FROM emp WHERE empno = paramA);
END //
DELIMITER ;

-- @+变量名称声明一个会话变量,作用域是整个会话
CALL pro_empno_avgsal(7788,@sal);
SELECT @sal;

-- 查看该表的存储过程
SELECT * FROM information_schema.ROUTINES

-- 删除存储过程
DROP PROCEDURE 存储过程名称
DROP PROCEDURE pro_empno;
DROP PROCEDURE pro_hello;
DROP PROCEDURE pro_empno_avgsal;
存储过程【练习题】
1.编写一个存储过程,要求能够对emp表中10部门的员工人数进行统计,并打印出来。

2.编写一个存储过程,要求能够对emp表中的所有员工平均工资进行统计,并打印出来。

3.编写一个存储过程,要求输入一个员工的编号,
过程能把该员工的所属部门名称和他的直接领导manager的姓名打印出来。

4.删除创建的所有存储过程
-------------------------------------------------------------------
2.控制结构
(1)IF 条件控制
/*
IF 条件判断1 then 执行语句1;
elseif  条件判断2 then 执行语句2;
...
elseif  条件判断N then 执行语句N;
else 执行语句N+1;
END IF;
*/

-- 输入一个部门编号,计算出该部门的平均工资
-- 如果平均工资低于1800,给该部门的员工涨薪300

DELIMITER //
CREATE PROCEDURE pro_sal(IN paramA INT)
BEGIN 
DECLARE avgsal FLOAT(7,2); -- 声明一个变量

SELECT AVG(sal) INTO avgsal FROM emp
WHERE deptno = paramA;

IF avgsal < 1800 THEN  UPDATE emp SET sal=sal+300 WHERE deptno = paramA;
END IF;

END //
DELIMITER ;

-- DECLARE 变量名 数据类型 [default 默认值] 
-- 该变量值只能在存储过程中使用 ,称为存储过程变量
CALL pro_sal(30);
SELECT AVG(sal) FROM emp WHERE deptno = 30;
SELECT * FROM emp WHERE deptno = 30;

ROLLBACK;
-- DROP PROCEDURE pro_sal;
-----------------------------------------------------------------
-- 输入一个部门编号,计算出该部门的平均工资
-- 如果平均工资低于1800,给该部门涨薪300
-- 如果平均工资在1800~2800之间,给该部门涨薪100
-- 如果平均工资大于2800,输出“工资太高了”

(2)循环控制
/*
while 进入循环的条件 DO
循环体;
end while;
*/

-- 创建一张表reg,用来存储用户的注册信息
-- 包含2个列 uname作为主键,upass 不能为空
-- 往表中插入100条数据
CREATE TABLE reg
(
uname VARCHAR(20) PRIMARY KEY,
upass VARCHAR(20) NOT NULL
);

SELECT * FROM reg

DELIMITER //
CREATE PROCEDURE pro_testdate(IN username VARCHAR(20),IN passwd VARCHAR(20), IN n INT)
BEGIN 

DECLARE varA INT DEFAULT 0;

WHILE varA < n DO
INSERT INTO reg
VALUES(CONCAT(username,varA),CONCAT(passwd,varA));

SET varA=varA+1;
END WHILE;

END //
DELIMITER ;

CALL pro_testdate('test','pass',100);

SELECT * FROM reg

-- drop table reg;
-- DROP PROCEDURE pro_testdate;
-- SELECT * FROM information_schema.ROUTINES

【练习题】
练习1:
输入一个部门编号,对该部门员工的薪资进行统计,要求:
用部门最高薪水-最低薪水的之差进行判断,
如果差距大于等于2000,输出标记‘H’
如果差距小于2000,大于等于1000,输出标记‘M’,
如果差距小于1000,输出标记‘L’
-- 提示:要求用IF实现

练习2:
输入一个员工编号,并对员工的工资进行判断,要求:
如果员工的工资等级为5,则输出wealthy
如果工资等级为4,输出rich
如果工资等级为3,输出average
如果工资等级为2,输出poor
如果工资等级为1,输出misery
-- 提示:用CASE实现
/*
case [变量]
when value1 then 执行语句1;
when value2 then 执行语句2;
……
when valueN then 执行语句N;
else 执行语句N+1;
end case;
*/

练习3:
编写一个函数,要求接受输入3个数字,表示三角形3边的长度。
如果输入的数字中包含0或负数,返回错误提示;
如果输入的数字不能组成三角形,返回错误提示;
如果能组成三角形,则需要判断组成的三角是不规则,等腰还是等边三角形,同样返回相应信息
-- 提示:用IF实现

练习4
自定义一张表test1,字段(id(主键),NAME(不能重复),phno)用循环向这张表中插入100行记录。
-- 提示:用while实现

【思考题】
复制N条雇员信息,要求重新创建100条

标签:--,语法,索引,emp,Mysql,TABLE,WHERE,SELECT,大全
From: https://blog.51cto.com/u_15834920/8031945

相关文章

  • 只此一篇,让你掌握Mysql所有语法及用法
    一、Mysql总结思维导图:二、SELECT(一)基础语法1.查询所有的列*SELECT*FROM表名;SELECT*FROMemp;SELECT*FROMdept;SELECT*FROMsalgrade;2.查询指定的列SELECT列名1,列名2...列名NFROM表名;SELECTename,job,salFROMemp;SELECTdeptno,dnameFROMdept;3.使用算......
  • Mysql函数大全
    前言MySQL提供了众多功能强大、方便易用的函数,使用这些函数,可以极大地提高用户对于数据库的管理效率,从而更加灵活地满足不同用户的需求。本文将MySQL的函数分类并汇总,以便以后用到的时候可以随时查看。数学函数(1)ABS(x)返回x的绝对值(2)PI()返回圆周率π,默认显示6位小数(3)SQRT(x)返回非......
  • 数据库中的中英文术语大全
    一、基础理论基础理论英文术语中文释义data数据database(DB)数据库databasesystem(dbs)数据库系统databasemanagementsystem数据库管理系统databaseadministrator数据库管理员relationalmodel关系模型relationaldatabase关系型数据库relation关系table表column列attribute属性row......
  • MySQL常用日期、时间函数(文末还有好东西哦)
    1、MySQL常用日期函数可以收藏的小图片2、MySQL常用日期函数可偷懒直接复制--1.4日期函数selectnow();#返回当前日期和时间selectcurrent_timestamp();#返回当前日期和时间selectcurrent_date();#返回当前日期selectcurrent_time();#返回当前时间selectdate_format(......
  • MySQL常用日期、时间函数(文末还有好东西哦)
    1、MySQL常用日期函数可以收藏的小图片2、MySQL常用日期函数可偷懒直接复制--1.4日期函数selectnow();#返回当前日期和时间selectcurrent_timestamp();#返回当前日期和时间selectcurrent_date();#返回当前日期selectcurrent_time();#返回当前时间selectdate_format(......
  • 爬取b站全站视频榜单保存到mysql
    爬取b站视频的全站板块的排行榜单提取出标题,地址,评论数量等等并且写入到mysql需要用到这四个库importrequestsimportjsonfromsqlalchemyimportcreate_engineimportpandas最后效果点赞分享视频公众号回复 b站全站榜单 获取源代码打开网站https://www.bilibili.com/v/popu......
  • mysql-关联查询 内连接 外连接(左外,右外,全连接) 交叉连接(迪卡积尔)
    mysql-关联查询关联查询:数据查询是Mysql数据库管理最重要的一个功能,关联查询是关系型数据库最主要的查询。包括内连接([inner]join…on),外连接(left/right[outer]join…on),全外连接,通过关联查询可实现多个表连接的条件关系查询得到预期结果。基本定义:[inner]join…on......
  • 最全常用正则表达式大全
    一、校验数字的表达式 1.数字:^[0-9]*$2.n位的数字:^\d{n}$3.至少n位的数字:^\d{n,}$4.m-n位的数字:^\d{m,n}$5.零和非零开头的数字:^(0|[1-9][0-9]*)$6.非零开头的最多带两位小数的数字:^([1-9][0-9]*)+(.[0-9]{1,2})?$7.带1-2位小数的正数或负数:^(\-)?\d+(\.\d{1,2})?......
  • mysql数据库笔记
    若要使用mysql,要先在项目/管理NuGet程序包中下载mysql.data才可以使用。server=127.0.0.1/localhost代表本机,端口号port默认是3306可以不写ExecuteReader——用于查询数据库。查询结果是返回MySqlDataReader对象MySqlDataReader包含sql语句执行的结果,并提供一个方法从结果中阅......
  • 《代码大全》阅读笔记
    形成一致的抽象,抽象能使你忽略无关的细节。合作设计,三个臭皮匠顶的上一个诸葛亮,含义是设计的过程中可以将自己的设计方案与同事讨论一番,询问同事的一些想法,讨论一些设计方案。类的接口应该展现一致的抽象层次编写子程序的理由:降低复杂度,易懂的抽象,避免代码重复,隐藏指针操作,......