当前位置: 首页 > news >正文

德兴高端网站设计上海app开发平台

德兴高端网站设计,上海app开发平台,做网站的外包公司上班好不好,wordpress手机投稿这是Mysql系列第18篇。 环境#xff1a;mysql5.7.25#xff0c;cmd命令中进行演示。 代码中被[]包含的表示可选#xff0c;|符号分开的表示可选其一。 上一篇存储过程自定义函数#xff0c;对存储过程和自定义函数做了一个简单的介绍#xff0c;但是如何能够写出复…这是Mysql系列第18篇。 环境mysql5.7.25cmd命令中进行演示。 代码中被[]包含的表示可选|符号分开的表示可选其一。 上一篇存储过程自定义函数对存储过程和自定义函数做了一个简单的介绍但是如何能够写出复杂的存储过程和函数呢 这需要我们熟练掌握流程控制语句才可以本文主要介绍mysql中流程控制语句的使用上干货。 本篇内容 if函数 case语句 if结构 while循环 repeat循环 loop循环 循环体控制语句 准备数据 /*建库javacode2018*/ drop database if exists javacode2018; create database javacode2018;/*切换到javacode2018库*/ use javacode2018;/*创建表t_user*/ DROP TABLE IF EXISTS t_user; CREATE TABLE t_user(id int PRIMARY KEY COMMENT 编号,sex TINYINT not null DEFAULT 1 COMMENT 性别,1:男,2:女,name VARCHAR(16) not NULL DEFAULT  COMMENT 姓名 )COMMENT 用户表;/*插入数据*/ INSERT INTO t_user VALUES (1,1,路人甲Java),(2,1,张学友),(3,2,王祖贤),(4,1,郭富城),(5,2,李嘉欣);SELECT * FROM t_user;DROP TABLE IF EXISTS test1; CREATE TABLE test1 (a int not null);DROP TABLE IF EXISTS test2; CREATE TABLE test2 (a int not null,b int NOT NULL );if函数 语法 if(条件表达式,值1,值2);if函数有3个参数。 当参数1为true的时候返回值1否则返回值2。 示例 需求查询t_user表数据返回编号、性别男、女、姓名。 分析一下数据库中性别用数字表示的我们需要将其转换为男、女可以使用if函数。 mysql SELECT id 编号,if(sex1,男,女) 性别,name 姓名 FROM t_user; ------------------------------- | 编号   | 性别   | 姓名          | ------------------------------- |      1 | 男     | 路人甲Java    | |      2 | 男     | 张学友        | |      3 | 女     | 王祖贤        | |      4 | 男     | 郭富城        | |      5 | 女     | 李嘉欣        | ------------------------------- 5 rows in set (0.00 sec)CASE结构 2种用法。 第1种用法 类似于java中的switch语句。 case 表达式 when 值1 then 结果1或者语句1如果是语句需要加分号 when 值2 then 结果2或者语句2 ... else 结果n或者语句n end [case] 如果是放在begin end之间需要加case如果在select后则不需要示例1select中使用 查询t_user表数据返回编号、性别男、女、姓名。 /*写法1类似于java中的if else*/ SELECT id 编号,(CASE sex WHEN 1 THEN 男 ELSE 女 END) 性别,name 姓名 FROM t_user; /*写法2类似于java中的if else if*/ SELECT id 编号,(CASE sex WHEN 1 then 男 WHEN 2 then 女 END) 性别,name 姓名 FROM t_user;示例2begin end中使用 写一个存储过程接受3个参数id性别男、女姓名然后插入到t_user表 创建存储过程 /*删除存储过程proc1*/ DROP PROCEDURE IF EXISTS proc1; /*s删除id6的记录*/ DELETE FROM t_user WHERE id6; /*声明结束符为$*/ DELIMITER $ /*创建存储过程proc1*/ CREATE PROCEDURE proc1(id int,sex_str varchar(8),name varchar(16))BEGIN/*声明变量v_sex用于存放性别*/DECLARE v_sex TINYINT UNSIGNED;/*根据sex_str的值来设置性别*/CASE sex_strwhen 男 THENSET v_sex  1;WHEN 女 THENSET v_sex  2;END CASE ;/*插入数据*/INSERT INTO t_user VALUES (id,v_sex,name);END $ /*结束符置为;*/ DELIMITER ;调用存储过程 CALL proc1(6,男,郭富城);查看效果 mysql select * from t_user; ------------------------ | id | sex | name          | ------------------------ |  1 |   1 | 路人甲Java    | |  2 |   1 | 张学友        | |  3 |   2 | 王祖贤        | |  4 |   1 | 郭富城        | |  5 |   2 | 李嘉欣        | |  6 |   1 | 郭富城        | ------------------------ 6 rows in set (0.00 sec)示例3函数中使用 需求写一个函数根据t_user表sex的值返回男女 创建函数 /*删除存储过程proc1*/ DROP FUNCTION IF EXISTS fun1; /*声明结束符为$*/ DELIMITER $ /*创建存储过程proc1*/ CREATE FUNCTION fun1(sex TINYINT UNSIGNED)RETURNS varchar(8)BEGIN/*声明变量v_sex用于存放性别*/DECLARE v_sex VARCHAR(8);CASE sexWHEN 1 THENSET v_sex:男;ELSESET v_sex:女;END CASE;RETURN v_sex;END $ /*结束符置为;*/ DELIMITER ;看一下效果 mysql select sex, fun1(sex) 性别,name FROM t_user; ---------------------------- | sex | 性别   | name          | ---------------------------- |   1 | 男     | 路人甲Java    | |   1 | 男     | 张学友        | |   2 | 女     | 王祖贤        | |   1 | 男     | 郭富城        | |   2 | 女     | 李嘉欣        | |   1 | 男     | 郭富城        | ---------------------------- 6 rows in set (0.00 sec)第2种用法 类似于java中多重if语句。 case when 条件1 then 结果1或者语句1如果是语句需要加分号 when 条件2 then 结果2或者语句2 ... else 结果n或者语句n end [case] 如果是放在begin end之间需要加case如果是在select后面case可以省略这种写法和1中的类似大家用上面这种语法实现第1中用法中的3个示例贴在留言中。 if结构 if结构类似于java中的 if..else if…else的语法如下 if 条件语句1 then 语句1; elseif 条件语句2 then 语句2; ... else 语句n; end if;只能使用在begin end之间。 示例 写一个存储过程实现用户数据的插入和新增如果id存在则修改不存在则新增并返回结果 /*删除id7的记录*/ DELETE FROM t_user WHERE id7; /*删除存储过程*/ DROP PROCEDURE IF EXISTS proc2; /*声明结束符为$*/ DELIMITER $ /*创建存储过程*/ CREATE PROCEDURE proc2(v_id int,v_sex varchar(8),v_name varchar(16),OUT result TINYINT)BEGINDECLARE v_count TINYINT DEFAULT 0;/*用来保存user记录的数量*//*根据v_id查询数据放入v_count中*/select count(id) into v_count from t_user where id  v_id;/*v_count0表示数据存在则修改否则新增*/if v_count0 THENBEGINDECLARE lsex TINYINT;select if(lsex男,1,2) into lsex;update t_user set sex  lsex,name  v_name where id  v_id;/*获取update影响行数*/select ROW_COUNT() INTO result;END;elseBEGINDECLARE lsex TINYINT;select if(lsex男,1,2) into lsex;insert into t_user VALUES (v_id,lsex,v_name);select 0 into result;END;END IF;END $ /*结束符置为;*/ DELIMITER ;看效果 mysql SELECT * FROM t_user; ------------------------ | id | sex | name          | ------------------------ |  1 |   1 | 路人甲Java    | |  2 |   1 | 张学友        | |  3 |   2 | 王祖贤        | |  4 |   1 | 郭富城        | |  5 |   2 | 李嘉欣        | |  6 |   1 | 郭富城        | ------------------------ 6 rows in set (0.00 sec)mysql CALL proc2(7,男,黎明,result); Query OK, 1 row affected (0.00 sec)mysql SELECT result; --------- | result | --------- |       0 | --------- 1 row in set (0.00 sec)mysql SELECT * FROM t_user; ------------------------ | id | sex | name          | ------------------------ |  1 |   1 | 路人甲Java    | |  2 |   1 | 张学友        | |  3 |   2 | 王祖贤        | |  4 |   1 | 郭富城        | |  5 |   2 | 李嘉欣        | |  6 |   1 | 郭富城        | |  7 |   2 | 黎明          | ------------------------ 7 rows in set (0.00 sec)mysql CALL proc2(7,男,梁朝伟,result); Query OK, 1 row affected (0.00 sec)mysql SELECT result; --------- | result | --------- |       1 | --------- 1 row in set (0.00 sec)mysql SELECT * FROM t_user; ------------------------ | id | sex | name          | ------------------------ |  1 |   1 | 路人甲Java    | |  2 |   1 | 张学友        | |  3 |   2 | 王祖贤        | |  4 |   1 | 郭富城        | |  5 |   2 | 李嘉欣        | |  6 |   1 | 郭富城        | |  7 |   2 | 梁朝伟        | ------------------------ 7 rows in set (0.00 sec)循环 mysql中循环有3种写法 while类似于java中的while循环 repeat类似于java中的do while循环 loop类似于java中的while(true)死循环需要在内部进行控制。 循环控制 对循环内部的流程进行控制如 结束本次循环 类似于java中的continue iterate 循环标签;退出循环 类似于java中的break leave 循环标签;下面我们分别介绍3种循环的使用。 while循环 类似于java中的while循环。 语法 [标签:]while 循环条件 do 循环体 end while [标签];标签是给while取个名字标签和iterate、leave结合用于在循环内部对循环进行控制如跳出循环、结束本次循环。 注意这个循环先判断条件条件成立之后才会执行循环体每次执行都会先进行判断。 示例1无循环控制语句 根据传入的参数v_count向test1表插入指定数量的数据。 /*删除test1表记录*/ DELETE FROM test1; /*删除存储过程*/ DROP PROCEDURE IF EXISTS proc3; /*声明结束符为$*/ DELIMITER $ /*创建存储过程*/ CREATE PROCEDURE proc3(v_count int)BEGINDECLARE i int DEFAULT 1;a:WHILE iv_count DOINSERT into test1 values (i);SET ii1;END WHILE;END $ /*结束符置为;*/ DELIMITER ;见效果 mysql CALL proc3(5); Query OK, 1 row affected (0.01 sec)mysql SELECT * from test1; --- | a | --- | 1 | | 2 | | 3 | | 4 | | 5 | --- 5 rows in set (0.00 sec)示例2添加leave控制语句 根据传入的参数v_count向test1表插入指定数量的数据当插入超过10条结束。 /*删除存储过程*/ DROP PROCEDURE IF EXISTS proc4; /*声明结束符为$*/ DELIMITER $ /*创建存储过程*/ CREATE PROCEDURE proc4(v_count int)BEGINDECLARE i int DEFAULT 1;a:WHILE iv_count DOINSERT into test1 values (i);/*判断i10离开循环a*/IF i10 THENLEAVE a;END IF;SET ii1;END WHILE;END $ /*结束符置为;*/ DELIMITER ;见效果 mysql DELETE FROM test1; Query OK, 20 rows affected (0.00 sec)mysql CALL proc4(20); Query OK, 1 row affected (0.02 sec)mysql SELECT * from test1; ---- | a  | ---- |  1 | |  2 | |  3 | |  4 | |  5 | |  6 | |  7 | |  8 | |  9 | | 10 | ---- 10 rows in set (0.00 sec)示例3添加iterate控制语句 根据传入的参数v_count向test1表插入指定数量的数据只插入偶数数据。 /*删除test1表记录*/ DELETE FROM test1; /*删除存储过程*/ DROP PROCEDURE IF EXISTS proc5; /*声明结束符为$*/ DELIMITER $ /*创建存储过程*/ CREATE PROCEDURE proc5(v_count int)BEGINDECLARE i int DEFAULT 0;a:WHILE iv_count DOSET ii1;/*如果i不为偶数跳过本次循环*/IF i%2!0 THENITERATE a;END IF;/*插入数据*/INSERT into test1 values (i);END WHILE;END $ /*结束符置为;*/ DELIMITER ;见效果 mysql DELETE FROM test1; Query OK, 5 rows affected (0.00 sec)mysql CALL proc5(10); Query OK, 1 row affected (0.01 sec)mysql SELECT * from test1; ---- | a  | ---- |  2 | |  4 | |  6 | |  8 | | 10 | ---- 5 rows in set (0.00 sec)示例4嵌套循环 test2表有2个字段a,b写一个存储过程2个参数v_a_countv_b_count)使用双重循环插入数据数据条件a的范围[1,v_a_count]、b的范围[1,v_b_count]所有偶数的组合。 /*删除存储过程*/ DROP PROCEDURE IF EXISTS proc8; /*声明结束符为$*/ DELIMITER $ /*创建存储过程*/ CREATE PROCEDURE proc8(v_a_count int,v_b_count int)BEGINDECLARE v_a int DEFAULT 0;DECLARE v_b int DEFAULT 0;a:WHILE v_av_a_count DOSET v_av_a1;SET v_b0;b:WHILE v_bv_b_count DOSET v_bv_b1;IF v_a%2!0 THENITERATE a;END IF;IF v_b%2!0 THENITERATE b;END IF;INSERT INTO test2 VALUES (v_a,v_b);END WHILE b;END WHILE a;END $ /*结束符置为;*/ DELIMITER ;代码中故意将ITERATE a;放在内层循环中主要让大家看一下效果。 见效果 mysql DELETE FROM test2; Query OK, 6 rows affected (0.00 sec)mysql CALL proc8(4,6); Query OK, 1 row affected (0.01 sec)mysql SELECT * from test2; ------ | a | b | ------ | 2 | 2 | | 2 | 4 | | 2 | 6 | | 4 | 2 | | 4 | 4 | | 4 | 6 | ------ 6 rows in set (0.00 sec)repeat循环 语法 [标签:]repeat 循环体; until 结束循环的条件 end repeat [标签];repeat循环类似于java中的do…while循环不管如何循环都会先执行一次然后再判断结束循环的条件不满足结束条件循环体继续执行。这块和while不同while是先判断条件是否成立再执行循环体。 示例1无循环控制语句 根据传入的参数v_count向test1表插入指定数量的数据。 /*删除存储过程*/ DROP PROCEDURE IF EXISTS proc6; /*声明结束符为$*/ DELIMITER $ /*创建存储过程*/ CREATE PROCEDURE proc6(v_count int)BEGINDECLARE i int DEFAULT 1;a:REPEATINSERT into test1 values (i);SET ii1;UNTIL iv_count END REPEAT;END $ /*结束符置为;*/ DELIMITER ;见效果 mysql DELETE FROM test1; Query OK, 1 row affected (0.00 sec)mysql CALL proc6(5); Query OK, 1 row affected (0.01 sec)mysql SELECT * from test1; --- | a | --- | 1 | | 2 | | 3 | | 4 | | 5 | --- 5 rows in set (0.00 sec)repeat中iterate和leave用法和while中类似这块的示例算是给大家留的作业写好的发在留言区谢谢。 loop循环 语法 [标签:]loop 循环体; end loop [标签];loop相当于一个死循环需要在循环体中使用iterate或者leave来控制循环的执行。 示例1无循环控制语句 根据传入的参数v_count向test1表插入指定数量的数据。 /*删除存储过程*/ DROP PROCEDURE IF EXISTS proc7; /*声明结束符为$*/ DELIMITER $ /*创建存储过程*/ CREATE PROCEDURE proc7(v_count int)BEGINDECLARE i int DEFAULT 0;a:LOOPSET ii1;/*当iv_count的时候退出循环*/IF iv_count THENLEAVE a;END IF;INSERT into test1 values (i);END LOOP a;END $ /*结束符置为;*/ DELIMITER ;见效果 mysql DELETE FROM test1; Query OK, 5 rows affected (0.00 sec)mysql CALL proc7(5); Query OK, 1 row affected (0.01 sec)mysql SELECT * from test1; --- | a | --- | 1 | | 2 | | 3 | | 4 | | 5 | --- 5 rows in set (0.00 sec)loop中iterate和leave用法和while中类似这块的示例算是给大家留的作业写好的发在留言区谢谢。 总结 本文主要介绍了mysql中控制流语句的使用请大家下去了多练习熟练掌握 if函数常用在select中 case语句有2种写法主要用在select、begin end中select中end后面可以省略casebegin end中使用不能省略case if语句用在begin end中 3种循环体的使用while类似于java中的while循环repeat类似于java中的do while循环loop类似于java中的死循环都用于begin end中 循环中体中的控制依靠leave和iterateleave类似于java中的break可以退出循环iterate类似于java中的continue可以结束本次循环
http://www.sczhlp.com/news/169893/

相关文章:

  • 做房产应看的网站好点子网站建设
  • 两学一做网站条幅开公众号
  • html 购物网站网站营销网站营销推广
  • 福州网站设计费用深圳小程序外包开发
  • 中山币做网站公司电子产品网站建设
  • 石家庄网站建站推广智通人才东莞招聘网
  • 六盘水建设网站网站留言短信通知
  • 给网站做收录较好的软件网站备案审批号
  • php学完可以做网站网站建设可用性的五个标准
  • 无锡网站建设套餐装修公司做网站好做吗
  • 门户网站有哪些中小学生做试卷的网站6
  • 智慧决策的透明化路径:“空白金兰契”架构下的“悟空备案制”研究
  • 网站怎么做响应式布局线上平台推广方式
  • 南京律师网站建设连云港今天的新消息
  • wordpress什么插件好网站推广策划案seo教程
  • 湘潭做网站 联系磐石网络wordpress uncode
  • 路由器上建网站网站建设以及seo
  • 高校信息化建设网站系统微信一起做网站吧
  • 广州万户网站公司wordpress添加搜索框
  • 上海网站建设 润中国能源建设集团有限公司网站
  • 个人博客网站模板源码德州网站开发人员
  • 卢氏县网站建设推广福田保安公司招聘
  • 做淘宝网站需要什么购买备案域名
  • 网站开发用php还是js台州自助建站系统
  • 做网站码中华智能自建代理网站
  • 网站建设都会用到哪些建站工具网站开发团队需要哪些人
  • 多语言网站制作重庆九龙网站建设
  • 英语网站建设网站保护等级是企业必须做的么
  • 网络公司做的网站我能改后台么wordpress 朋友圈插件
  • zencart 网站入侵公司网页网站建设 ppt模板