【mysql的编程专题①】流程控制与其他语法
怎么入门数据库编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《【mysql的编程专题①】流程控制与其他语法》,涉及到MySQL,有需要的可以收藏一下
流程控制与内置函数,一般用在select的field字段上,或者用在函数,存储过程,触发器中;
如果用在select上就会随着query出来的row来隐式迭代;
注释与语句结束符
语句结束符
默认有两个:
DECLARE var_name[,...] type [DEFAULT value]
其中, DECLARE关键字是用来声明变量的;var_name参数是变量的名称,这里可以同时定义多个变量;type参数用来指定变量的类型;DEFAULT value子句将变量默认值设置为value,没有使用DEFAULT子句时,默认值为NULL。只能用在存储过程或者函数内部
在过程中定义的变量并不是真正的定义,你只是在BEGIN/END(即复合语句)块内定义了而已。注意这些变量和会话变量不一样,不能使用修饰符@你必须清楚的在BEGIN/END块中声明变量和它们的类型。变量一旦声明,你就能在任何能使用会话变量、文字、列名的地方使用。还需要注意的一点是,在一个块内,我们需要把所有要使用的变量先声明,才能在后面使用,并且不能在声明变量的语句间夹杂其他使用变量的语句,否会报语法错误。
CREATE PROCEDURE P5() BEGIN DECLARE a INT; DECLARE b INT; SET a = 5; SET b = 5; INSERT INTO t VALUES(a); SELECT s1 FROM t WHERE s1>= b; END; ------------------------------------------------- mysql> CALL p5(); +----+ | s1 | +----+ | 5 | | 5 | +----+ 2 rows in set Query OK, 0 rows affected
MySQL中可以使用SET关键字来为变量赋值。SET语句的基本语法如下:
SET var_name = expr [, var_name = expr] ...
MySQL中还可以使用SELECT…INTO语句为变量赋值。其基本语法如下:
SELECT col_name[,…] INTO var_name[,…] FROM table_name WEHRE condition
其中,col_name参数表示查询的字段名称;var_name参数是变量的名称;table_name参数指表的名称;condition参数指查询条件。
-- 查看系统变量 show variables [like pattern] show variables like "innodb%"; -- set 变量名=变量值; 注意:为了区分用户自定义变量和系统变量,需要在用户自定义变量名称前加@符号。例如 set @name=’John’; -- 如果在存储过程或者函数中用DECLARE来预先定义了某个变量,后面的set可以不用加@,详见后文例子; set @userTotel = (select count(*) from users); -- Set赋值用法的变量值也可是标量查询的结果 -- select 字段 from 表名 into @变量名 select nickname from users ORDER BY user_money desc limit 1 into @richName; SELECT id,data INTO x,y FROM test.t1 LIMIT 1; -- 这个SELECT语法把选定的列直接存储到变量。因此,只有单一的行可以被取回 -- select @变量名:=变量值 与 select @变量名=变量值 set @who = 'zhouzhou'; select @who='小李'; -- 注意:此处不是赋值操作,而是变量的判断,如果@who变量是已经存在了,那就判断@who中的值是否等于'小李',返回0或1;如果@who的变量不存在就返回NULL;
注意
变量的有效期为会话结束后,变量就失效(即断开连接后,变量失效)!
变量的作用域: 用户定义的变量是全局的。但在函数内定义的变量则是局部的。
变量的数据类型与字段的数据类型一致!
输出变量
select @who;
分支语句
IF
语法
IF search_condition THEN statement_list [ELSEIF search_condition THEN statement_list] ... [ELSE statement_list] END IF;
statement_list: 多条语句由
delimiter $ CREATE PROCEDURE `hd`(IN `arg` TINYINT) BEGIN DECLARE `age` TINYINT DEFAULT 0; SET `age` = `arg`; IF `age`create procedure proc_getGrade (stu_no varchar(20),cour_no varchar(10)) begin declare stu_grade float; select grade into stu_grade from grade where student_no=stu_no and course_no=cour_no; if stu_grade>=90 then select stu_grade,'a'; elseif stu_grade=80 then select stu_grade,'b'; elseif stu_grade=70 then select stu_grade,'c'; elseif stu_grade=60 then select stu_grade,'d'; else select stu_grade,'e'; end if; end三元表达式
SELECT IF(@a=1,'真','失败');IFNULL(字段,值)
select age,ifnull(age,"空") from c; -- 如果age的值为null就返回空;NULLIF(expr1,expr2)
-- 如果表达式1=表达式2,则返回null,否则返回第1个表达式 SELECT NULLIF(5,5); -- null SELECT NULLIF(10,4); -- 10case
CASE case_value WHEN when_value THEN statement_list [WHEN when_value THEN statement_list] ... [ELSE statement_list] END CASE 或者 CASE WHEN search_condition THEN statement_list [WHEN search_condition THEN statement_list] ... [ELSE statement_list] END CASEExample1
delimiter $ CREATE PROCEDURE `pro2`(INOUT `arg` INT) BEGIN DECLARE `i` INT DEFAULT 0; SET `i` = `arg`; CASE `i` WHEN 1 THEN SELECT "sina"; WHEN 2 THEN SELECT "baidu"; ELSE SELECT "163"; END CASE; END; $ delimiter ;Example2
delimiter $ CREATE PROCEDURE `pro3`(INOUT `arg` INT) BEGIN DECLARE `i` INT DEFAULT 0; SET `i` = `arg`; CASE WHEN i = 1 THEN SELECT "sina"; WHEN i = 2 THEN SELECT "baidu"; ELSE SELECT "163"; END CASE; END; $ delimiter ;循环
leave
退出循环
LEAVE label -- 退出循环,注意如果要使用leave的话,循环就必须得带上leave;while
[begin_label:] WHILE search_condition DO statement_list END WHILE [end_label]Example1
delimiter $ CREATE PROCEDURE `createstu`(IN `num` INT) BEGIN DECLARE `i` INT DEFAULT 0; DECLARE `yeard` DATE; WHILE `num`>0 DO SET `yeard` = DATE_SUB("2000-1-1",INTERVAL `i` DAY); INSERT INTO `test` (`sname`,`birthday`) VALUES(MD5(`i`),`yeard`); SET `i`=`i`+1; SET `num`=`num`-1; END WHILE; END$loop
[begin_label:] LOOP statement_list END LOOP [end_label]Example1
delimiter $ create procedure t_loop() begin declare i int; set i = 0; loop_label:loop insert into test(sname,birthday) values(md5(i),2005); set i = i + 1; if i > 100 then leave loop_label; -- 注意这里的label是必须的哦; end if; end loop; end$ delimiter ;loop是在执行后检查结果,while是在执行前检查结果
repeat
[begin_label:] REPEAT statement_list UNTIL search_condition -- REPEAT语句内的语句或语句群被重复,直至search_condition 为真。 END REPEAT [end_label]Example1
delimiter $ create procedure t_repeat() begin declare i int; set i = 100; repeat insert into test(sname,birthday) values(md5(i),1988); set i = i + 5; until i > 10000 -- 注意until此处没有分号,是为和下面的end链接一起的; end repeat; end;$其他
INSERT INTO SELECT
语法
Insert into Table2(field1,field2,...) select value1,value2,... from Table1要求目标表Table2必须存在,如果目标table2已经存在了,并且和table1的结构一样的话,可以直接
SELECT vale1, value2 into Table2 from Table1
要求目标表Table2不存在,因为在插入时会自动创建表Table2,并将Table1中指定字段数据复制到Table2中。
注意: MySQL不支持Sybase SQL扩展:
replace into table (id,name) values('1','aa'),('2','bb') -- 此语句的作用是向表table中插入两条记录。如果主键id为1或2不存在就相当于insert into table (id,name) values('1','aa'),('2','bb') ,如果存在相同的值则不会插入数据create...select
-- 创建表并插入它表的数据进来; CREATE TABLE tdb_goods_brands ( brand_id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT, brand_name VARCHAR (40) NOT NULL ) ENGINE = INNODB AUTO_INCREMENT = 1 DEFAULT CHARSET = utf8 COMMENT = '用户信息表' SELECT brand_name FROM tdb_goods GROUP BY brand_name;理论要掌握,实操不能落!以上关于《【mysql的编程专题①】流程控制与其他语法》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

- 上一篇
- PHP防止同一个账号,同时在多个不同设备登录

- 下一篇
- Linux下MySQL编译安装及初始化
-
- 数据库 · MySQL | 14小时前 | 数据类型 扩展性 存储引擎 CREATETABLE 约束条件
- MySQL建表攻略:详解数据表创建方法
- 265浏览 收藏
-
- 数据库 · MySQL | 18小时前 | mysql 字符集 中文乱码 utf8mb4 utf8mb4_unicode_ci
- MySQL中文乱码解决方案与字符集修改命令大全
- 339浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 笔灵AI生成答辩PPT
- 探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
- 23次使用
-
- 知网AIGC检测服务系统
- 知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
- 36次使用
-
- AIGC检测-Aibiye
- AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
- 37次使用
-
- 易笔AI论文
- 易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
- 47次使用
-
- 笔启AI论文写作平台
- 笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
- 40次使用
-
- golang MySQL实现对数据库表存储获取操作示例
- 2022-12-22 499浏览
-
- 搞一个自娱自乐的博客(二) 架构搭建
- 2023-02-16 244浏览
-
- B-Tree、B+Tree以及B-link Tree
- 2023-01-19 235浏览
-
- mysql面试题
- 2023-01-17 157浏览
-
- MySQL数据表简单查询
- 2023-01-10 101浏览