微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

mysql编程

由于数据库功能强大,逻辑复杂,单纯靠sql已经无法满足我们的使用、开发需要,所以mysql或各个数据库服务都有自己一些额外的语法可以配合sql语句一起使用来实现更复杂的逻辑。

MysqL编程的应用场景

  1. 存储过程
  2. 自定义函数
  3. 触发器等

语法规则

(1)注释

行注释 : # 和 --加空格
块注释:/**/

(2)语句结束符

MysqL认语句结束符是分号 ;
而在MySQL命令行下额外提供了两个 \g 和 \G
可以使用 delimiter + 新语句结束符来修改为新的语句结束符
例如 delimiter $$ 这样会把语句结束符修改为 $$

(3)变量

系统变量

此处系统变量是指系统初始化时定义好的变量,这些系统变量是为了描述MysqL(或其它数据库)所处的环境,所以我理解为MysqL系统变量。

用户自定义变量
  • 定义语法

    1. set 变量名=变量值;为了区分系统变量、字段名、和自定义变量。自定义变量我们都以@开头。比如:
      br/>为了区分系统变量、字段名、和自定义变量。自定义变量我们都以@开头。比如:
      set @aa = 1;
      如果不以@开头,那么MysqL系统会认为你要修改一个系统变量,如果有同名的系统变量,其值被修改后可能会发生意外的情况,如果没有同名的系统变量,MysqL则会报错。

    2. select into 语法
      select 字段名列表 into 变量名列表;
      select 值列表 into 变量名列表;
      例如:
      select 1,2,3 into @a,@b,@c ;

    3. := 赋值语法
      由于在select语句中等号(=)的特殊性。一个=是比较,所以我们用 := 来赋值。:= 在set中也可以使用,而在select中只能用 :=
    查看自定义变量

    要查看已定义的变量,我们只需“select 变量名;”即可

  • 生命周期
    自定义变量的生命周期伴随操作MysqL时整个会话周期,就是从开始连接上数据库到断开数据库,整个过程中有效。

  • 作用域
    全局作用域,如果是在函数内部,那么作用域就是函数内部。

    (4)运算符

    运算符在多种语言几乎百分之九十都相同,无非是算数运算符,逻辑运算符和位运算符等。

    (5)流程控制

    分支结构
    if

    if condition then statement<br/>elseif contdition then statement1<br/>else statement2<br/>end if

    case

    CASE case_value<br/>WHEN when_value THEN statement_list<br/>[WHEN when_value THEN statement_list] ...<br/>[ELSE statement_list]<br/>END CASE
    或者
    CASE<br/>WHEN search_condition THEN statement_list<br/>[WHEN search_condition THEN statement_list] ...<br/>[ELSE statement_list]<br/>END CASE

    循环语句
    loop
    repeat
    while

    由于这种循环结构无法单独演示,所以我打算在以后的存储过程中详细学习,其语法可参考 https://dev.MysqL.com/doc/refman/8.0/en/flow-control-statements.html 官方文档

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐