由于数据库的功能强大,逻辑复杂,单纯靠sql已经无法满足我们的使用、开发需要,所以MySQL或各个数据库服务都有自己一些额外的语法可以配合sql语句一起使用来实现更复杂的逻辑。
站在用户的角度思考问题,与客户深入沟通,找到永昌网站设计与永昌网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站制作、做网站、企业官网、英文网站、手机端网站、网站推广、域名申请、网页空间、企业邮箱。业务覆盖永昌地区。
mysql编程的应用场景
- 存储过程
- 自定义函数
- 触发器等
语法规则
(1)注释
行注释 : # 和 --加空格
块注释:/**/
(2)语句结束符
mysql的默认语句结束符是分号 ;
而在mysql命令行下额外提供了两个 \g 和 \G
可以使用 delimiter + 新语句结束符来修改为新的语句结束符
例如 delimiter $$
这样会把语句结束符修改为 $$
(3)变量
系统变量
此处系统变量是指系统初始化时定义好的变量,这些系统变量是为了描述mysql(或其它数据库)所处的环境,所以我理解为mysql系统变量。
用户自定义变量
定义语法
set 变量名=变量值;为了区分系统变量、字段名、和自定义变量。自定义变量我们都以@开头。比如:
br/>为了区分系统变量、字段名、和自定义变量。自定义变量我们都以@开头。比如:
set @aa = 1;
如果不以@开头,那么mysql系统会认为你要修改一个系统变量,如果有同名的系统变量,其值被修改后可能会发生意外的情况,如果没有同名的系统变量,mysql则会报错。select into 语法
select 字段名列表 into 变量名列表;
select 值列表 into 变量名列表;
例如:select 1,2,3 into @a,@b,@c ;
- := 赋值语法
由于在select语句中等号(=)的特殊性。一个=是比较,所以我们用 := 来赋值。:= 在set中也可以使用,而在select中只能用 :=
查看自定义变量
要查看已定义的变量,我们只需“select 变量名;”即可
生命周期
自定义变量的生命周期伴随操作mysql时整个会话周期,就是从开始连接上数据库到断开数据库,整个过程中有效。作用域
全局作用域,如果是在函数内部,那么作用域就是函数内部。(4)运算符
运算符在多种语言几乎百分之九十都相同,无非是算数运算符,逻辑运算符和位运算符等。
(5)流程控制
分支结构
if
if condition then statement
elseif contdition then statement1
else statement2
end ifcase
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 CASE循环语句
loop
repeat
while
由于这种循环结构无法单独演示,所以我打算在以后的存储过程中详细学习,其语法可参考 https://dev.mysql.com/doc/refman/8.0/en/flow-control-statements.html 官方文档
名称栏目:mysql编程
文章网址:http://lswzjz.com/article/psghjp.html