>  기사  >  데이터 베이스  >  MySQL 강의 6: 프로세스 제어

MySQL 강의 6: 프로세스 제어

coldplay.xixi
coldplay.xixi앞으로
2021-03-01 09:10:012430검색

MySQL 강의 6: 프로세스 제어

무료 학습 권장사항: mysql 비디오 튜토리얼

Article 디렉토리

  • 브랜치 구조
    • IF 함수
    • 케이스 구조
    • IF 구조
  • 루프 구조

mysql의 흐름 제어는 다른 프로그래밍 언어의 흐름 제어와 유사하며 순차 구조, 분기 구조, 루프의 세 가지 유형으로 나뉩니다. 구조 코드>. 기본적으로 이전 글에서 사용한 순차구조(IF함수 제외)를 주로 소개하며, 분기구조와 루프구조를 주로 소개합니다. 顺序结构分支结构循环结构。前几篇文章中用到的基本上都是顺序结构(除了IF函数),下面主要针对分支结构和循环结构进行介绍。

分支结构

IF函数

语法:IF(表达式1,表达式2,表达式3)
说明:如果表达式1成立,则执行表达式2,否则执行表达式3

case结构

case结构有两种语法:
MySQL 강의 6: 프로세스 제어
特点:

  • 作为表达式使用,嵌套在其他语句中使用,在BEGIN-END中和BEGIN-END外都可以使用。
  • 作为独立的语句使用,只能放在BEGIN-END中。
  • 如果省略ELSE,且所有的WHEN都不满足,则返回null。
【演示case作为独立的语句】# 创建存储过程,根据传入的成绩,显示等级:90-100显示A 、 80-90显示B、60-80显示C、否则显示DCREATE PROCEDURE test_case(IN score INT)BEGIN
	CASE
	WHEN score>=90 AND score=80 THEN SELECT 'B';
	WHEN score>=60 THEN SELECT 'C';
	ELSE SELECT 'D';
	END CASE;END $CALL test_case(95)$

IF结构

语法:
if 条件1 then 语句1;
elseif 条件2 then 语句2;
...
[else 语句n;]
end if;

【演示IF结构】# 根据传入的成绩,显示等级:90-100显示A 、 80-90显示B、60-80显示C、否则显示DCREATE FUNCTION test_if(score INT) RETURNS CHARBEGIN
	IF score>=90 AND score=80 THEN RETURN 'B';
	ELSEIF score>=60 THEN RETURN 'C';
	ELSE RETURN 'D';
	END IF;END $SELECT test_if(61)$

循环结构

mysql中的循环结构有下面三种:

名称 语法 特点
while MySQL 강의 6: 프로세스 제어 先判断后执行
repeat,类似Java中的do-wile语句 MySQL 강의 6: 프로세스 제어 先执行后判断
loop MySQL 강의 6: 프로세스 제어 没有条件的死循环

可以在循环控制中使用的关键字有iterate(类似于Java中的continue)和leave

분기 구조


MySQL 강의 6: 프로세스 제어

IF 함수

구문: IF(식 1, 식 2, 식 3) 설명: 식 1이 true이면 식 2를 실행합니다. 그렇지 않으면, 표현식 3 실행

케이스 구조

케이스 구조에는 두 가지 구문이 있습니다: 여기에 이미지 설명 삽입특징:
🎜 표현식으로 사용🎜, 다른 문에 중첩, BEGIN-END 코드 내부에서 모두 사용할 수 있음> 및 <code>BEGIN-END 외부. 🎜🎜🎜은 독립문🎜으로 사용되며 BEGIN-END에만 배치할 수 있습니다. 🎜🎜ELSE를 생략하고 WHEN을 모두 만족하지 않으면 null이 반환됩니다. 🎜🎜
【演示简单的循环结构】# 案例:批量插入,根据次数插入到admin表中多条记录.CREATE PROCEDURE pro_while1(IN insertCount INT)BEGIN
	DECLARE i INT DEFAULT 1;
	WHILE i20则停止TRUNCATE TABLE admin$DROP PROCEDURE test_while1$CREATE PROCEDURE test_while1(IN insertCount INT)BEGIN
	DECLARE i INT DEFAULT 1;
	a:WHILE i=20 THEN LEAVE a;
		END IF;
		SET i=i+1;
	END WHILE a;END $CALL test_while1(100)$--------------------------------------------------------------------------------------------【演示添加了iterate的语句】# 案例:批量插入,根据次数插入到admin表中,直插入偶数次CREATE PROCEDURE test_while2(IN insertCount INT)BEGIN
	DECLARE i INT DEFAULT 0;
	a:WHILE i🎜🎜IF 구조🎜🎜🎜🎜 문법: 🎜🎜<code>if 조건 1 then 명령문 1;</code>🎜<code>elseif 조건 2 then 명령문 2;</code>🎜<code>.. .</code>🎜<code>[else 문 n;]</code>🎜<code>end if;</code>🎜<pre class="brush:php;toolbar:false">【习题答案】DROP TABLE IF EXISTS stringcontent;CREATE TABLE stringcontent(
	id INT PRIMARY KEY AUTO_INCREMENT,
	content VARCHAR(20)
	);DELIMITER $CREATE PROCEDURE test_pro1(IN insertCount INT)BEGIN
	DECLARE i INT DEFAULT 1;#定义一个循环变量i,表示插入次数
	DECLARE str VARCHAR(26) DEFAULT 'abcdefghijklmnopqrstuvwxyz';
	DECLARE strIndex INT DEFAULT 1;#代表起始索引
	DECLARE len INT DEFAULT 1;#代表截取的字符的长度
	WHILE i<h1>루프 구조</h1>🎜mysql의 루프 구조에는 다음이 포함됩니다. 세 가지 유형: 🎜
이름 구문 기능
🎜while🎜 여기에 그림 설명 삽입 먼저 판단한 후 실행
🎜repeat🎜, Java의 do-wile 문과 유사 여기에 이미지 설명 삽입 먼저 실행한 후 판단
🎜loop🎜 여기에 그림 설명 삽입 무조건 무한 루프
🎜루프 제어에 사용할 수 있는 키워드는 iterate(Java의 continue와 유사) 및 leave(Java의 break와 유사)입니다🎜rrreee🎜🎜Learn 프로세스 이해 mysql을 제어하려면 다음 연습을 완료해 보세요🎜🎜🎜🎜rrreee🎜🎜🎜더 많은 관련 무료 학습 권장 사항:🎜🎜🎜mysql 튜토리얼🎜🎜🎜(동영상)🎜🎜🎜

위 내용은 MySQL 강의 6: 프로세스 제어의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 csdn.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제