前言:导入数据
点击查看代码
| |
| |
| |
| |
| |
| ; |
| |
| ; |
| |
| ; |
| ; |
| ; |
| ; |
| CREATE DATABASE `girls` ; |
| |
| USE `girls`; |
| |
| |
| |
| DROP TABLE IF EXISTS `admin`; |
| |
| CREATE TABLE `admin` ( |
| `id` int(11) NOT NULL AUTO_INCREMENT, |
| `username` varchar(10) NOT NULL, |
| `password` varchar(10) NOT NULL, |
| PRIMARY KEY (`id`) |
| ) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8; |
| |
| |
| |
| insert into `admin`(`id`,`username`,`password`) values (1,'john','8888'),(2,'lyt','6666'); |
| |
| |
| |
| DROP TABLE IF EXISTS `beauty`; |
| |
| CREATE TABLE `beauty` ( |
| `id` int(11) NOT NULL AUTO_INCREMENT, |
| `name` varchar(50) NOT NULL, |
| `sex` char(1) DEFAULT '濂?, |
| `borndate` datetime DEFAULT '1987-01-01 00:00:00', |
| `phone` varchar(11) NOT NULL, |
| `photo` blob, |
| `boyfriend_id` int(11) DEFAULT NULL, |
| PRIMARY KEY (`id`) |
| ) ENGINE=InnoDB AUTO_INCREMENT=13 DEFAULT CHARSET=utf8; |
| |
| /*Data for the table `beauty` */ |
| |
| insert into `beauty`(`id`,`name`,`sex`,`borndate`,`phone`,`photo`,`boyfriend_id`) values (1,'鏌冲博','濂?,'1988-02-03 00:00:00','18209876577',NULL,8),(2,'鑻嶈€佸笀','濂?,'1987-12-30 00:00:00','18219876577',NULL,9),(3,'Angelababy','濂?,'1989-02-03 00:00:00','18209876567',NULL,3),(4,'鐑反','濂?,'1993-02-03 00:00:00','18209876579',NULL,2),(5,'鍛ㄥ啲闆?,'濂?,'1992-02-03 00:00:00','18209179577',NULL,9),(6,'鍛ㄨ姺鑻?,'濂?,'1988-02-03 00:00:00','18209876577',NULL,1),(7,'宀崇伒鐝?,'濂?,'1987-12-30 00:00:00','18219876577',NULL,9),(8,'灏忔槶','濂?,'1989-02-03 00:00:00','18209876567',NULL,1),(9,'鍙屽効','濂?,'1993-02-03 00:00:00','18209876579',NULL,9),(10,'鐜嬭瀚?,'濂?,'1992-02-03 00:00:00','18209179577',NULL,4),(11,'澶忛洩','濂?,'1993-02-03 00:00:00','18209876579',NULL,9),(12,'璧垫晱','濂?,'1992-02-03 00:00:00','18209179577',NULL,1); |
| |
| /*Table structure for table `boys` */ |
| |
| DROP TABLE IF EXISTS `boys`; |
| |
| CREATE TABLE `boys` ( |
| `id` int(11) NOT NULL AUTO_INCREMENT, |
| `boyName` varchar(20) DEFAULT NULL, |
| `userCP` int(11) DEFAULT NULL, |
| PRIMARY KEY (`id`) |
| ) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8; |
| |
| /*Data for the table `boys` */ |
| |
| insert into `boys`(`id`,`boyName`,`userCP`) values (1,'寮犳棤蹇?,100),(2,'楣挎櫁',800),(3,'榛勬檽鏄?,50),(4,'娈佃獕',300); |
| |
| /*!40101 SET SQL_MODE=@OLD_SQL_MODE */; |
| /*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */; |
| /*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */; |
| /*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */; |
| |
1. 存储过程
| 含义:一组预先编译好的SQL语句的集合,理解成批处理语句 |
| |
| 好处: |
| 1.提高代码的重用性 |
| 2.简化操作 |
| 3.减少了编译次数并且减少了和数据库服务的连接次数,提高了效率 |
| |
| 创建: |
| create procedure 存储过程名(参数列表) |
| BEGIN |
| 存储过程体(一组合法的SQL语句) |
| END |
| |
| 注意: |
| 1.参数列表包含3部分:参数模式,参数名,参数类型 |
| 举例: |
| IN stuname varchar(20) |
| 参数模式: |
| IN:该参数可以作为输入,也就是该参数需要调用方传入值。 |
| OUT:该参数可以作为输出,也就是该参数可以作为返回值。 |
| INOUT:该参数既可以作为输入又可以作为输出,也就是该参数既需要传入值,又可以返回值。 |
| 2.如果存储过程体仅仅只有一句话,BEGIN END可以省略 |
| 存储过程体中的每条SQL语句的结尾要求必须加分号。 |
| 存储过程的结尾可以使用DELIMITER重写设置。 |
| 语法: |
| DELIMITER 结束标记 |
| 案例: |
| DELIMITER $ |
| |
| 调用: |
| CALL 存储过程名(实参列表); |
2. 存储过程案例
| 定义存储过程: |
| delimiter $ |
| create procedure mypl() |
| begin |
| insert into admin(username, password) |
| values('john1', '0000'), ('lily', '9999'), ('tom', '9999'), ('jack', '9999'), ('marry', '9999'); |
| end $ |
| |
| 调用存储过程: |
| call mypl()$ |
3. 创建带IN模式参数的存储过程
| 说明:如果出现字符集不一致的情况,写下面的语句 |
| set names gbk$ |
| |
| 案例1:创建存储过程实现 |
| delimiter $ |
| create procedure myp2(IN beautyName varchar(20)) |
| BEGIN |
| SELECT bo.* |
| from boys bo |
| right join beauty b on bo.id = b.boyfriend_id |
| where b.name = beautyName; |
| END $ |
| |
| 调用: |
| CALL myp2('柳岩')$ |
| |
| 案例2:创建存储过程实现,用户是否登录成功 |
| delimiter $ |
| create procedure myp(IN username varchar(20), IN password varchar(20)) |
| BEGIN |
| declare result int default 0; # 声明并初始化 |
| |
| select count(*) into result # 赋值 |
| from admin |
| where username = admin.username |
| and `password` = admin.password; |
| |
| select if(result>0, '成功', '失败'); # 使用 |
| END $ |
| |
| delimiter $ |
| call myp('张飞', '8888')$ |
4. 创建带IN模式参数的存储过程
| 案例1:根据女神名,返回对应的男神名 |
| delimiter $ |
| create procedure myp6(IN beautyName varchar(20), OUT boyName varchar(20)) |
| BEGIN |
| select bo.boyName into @boyName |
| from boys bo |
| inner join beauty b |
| on bo.id = b.boyfriend_id |
| where b.name = beautyName; |
| END $ |
| |
| # 调用 |
| delimiter $ |
| call myp5('小昭', @boyName) $ |
| SELECT @boyName$ |
| |
| |
| 案例2:根据女神名,返回对应的男神名和男神魅力值 |
| delimiter $ |
| create procedure myp8 |
| (IN beautyName varchar(20), |
| OUT boyName varchar(20), |
| OUT userCP varchar(20) |
| ) |
| BEGIN |
| select bo.boyName, bo.userCP into @boyName, @userCP |
| from boys bo |
| inner join beauty b |
| on bo.id = b.boyfriend_id |
| where b.name = beautyName; |
| END $ |
| |
| # 调用 |
| delimiter $ |
| call myp7('小昭', @boyName, @userCP) $ |
| SELECT @boyName,@userCP$ |
5. 创建带INOUT模式参数的存储过程
| 案例1:传入a和b两个值,最终a和b都翻倍并返回 |
| delimiter $ |
| create procedure myp8(INOUT a int, INOUT b int) |
| BEGIN |
| set a = a * 2; |
| set b = b * 2; |
| END $ |
| |
| delimiter $ |
| set @m = 10$ |
| set @n = 20$ |
| select @m,@n$ |
案例练习
| 1. 创建存储过程实现传入用户名和密码,插入到admin表中 |
| delimiter $ |
| create procedure myp10(IN name varchar(30), IN psw varchar(30)) |
| BEGIN |
| insert into admin(username, password) values(name, psw); |
| END $ |
| |
| delimiter $ |
| call myp10('jsq', 'jsqmm') $ |
| |
| 2. 创建存储过程实现传入女神编号,返回女神名称和女神电话 |
| delimiter $ |
| create procedure myp11(IN code int, INOUT name varchar(30), INOUT phone varchar(30)) |
| BEGIN |
| select beauty.name, beauty.phone into name, phone |
| from beauty |
| where beauty.id = code; |
| END $ |
| |
| delimiter $ |
| call myp11(1, @name, @phone) $ |
| select @name,@phone $ |
| |
| 3. 创建存储过程实现传入两个女神生日,返回大小 |
| delimiter $ |
| create procedure myp13(IN birth1 datetime, IN birth2 datetime, OUT compare varchar(30)) |
| BEGIN |
| select if(datediff(birth1,birth2)>0,'前者大','后者大') into compare; |
| END $ |
| |
| delimiter $ |
| call myp13('2021-2-1','2021-3-4', @result) $ |
| select @result $ |
5. 删除存储过程
6. 查看存储过程的信息
| show create procedure 存储过程名; |
说明没有修改存储过程的原因
因为不能修改存储过程中的逻辑语句
案例练习
| 1. 创建存储过程实现传入一个日期,格式化成xx年xx月xx日并返回 |
| delimiter $ |
| create procedure myp16(IN d datetime, OUT strdate varchar(30)) |
| BEGIN |
| select DATE_FORMAT(d,"%Y年%m月%d日") into strdate; |
| END $ |
| |
| delimiter $ |
| set @result = '2021-04-03' $ |
| call myp16(@result, @s) $ |
| select @s $ |
| |
| 2. 创建存储过程实现传入女神名称,返回:女神 and 男神 格式的字符串 |
| 如:传入:小昭 |
| 返回:小昭AND张无忌 |
| delimiter $ |
| create procedure myp23(IN n varchar(30), OUT strname varchar(60)) |
| BEGIN |
| select CONCAT(n, ' AND ', ifnull(boys.boyName, 'null')) into strname |
| from beauty left JOIN boys |
| on beauty.boyfriend_id = boys.id |
| where beauty.name = n; |
| END $ |
| |
| delimiter $ |
| call myp23('柳岩', @s) $ |
| select @s $ |
| |
| 3. 创建存储过程,更具传入的条目数和起始索引,查询beauty表的记录 |
| delimiter $ |
| create procedure myp25(IN beginIndex int, IN size int) |
| BEGIN |
| select * |
| from beauty |
| limit beginIndex, size; |
| END $ |
| |
| delimiter $ |
| call myp25(3, 6) $ |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?