流程控制
所谓流程控制, 无非就是 分支 和 循环
流程控制.pngif else
假设有一个教师表, 有
id
,name
,sex
,salary
四个字段(ID,姓名,性别,工资), 根据不同的工资, 分别显示不同的身份
输入id, 如果工资大于5000, 输出土豪
, 如果小于1500, 输出low 逼
, 如果1500到5000之间, 输出马马虎虎
, 如果没有, 则显示''查无此人''
drop table if exists teacher;
CREATE TABLE `teacher` (
`id` int(11) NOT NULL auto_increment primary key,
`salary` int(11) NOT NULL,
`sex` tinyint(1) NOT NULL comment '1 for male, 2 for female',
`name` char(10) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT INTO `teacher`
(`id`, `salary`, `sex`, `name`)
VALUES
(1, 1500, 1, '教师1');
INSERT INTO `teacher`
(`id`, `salary`, `sex`, `name`)
VALUES
(2, 5500, 2, '教师2');
INSERT INTO `teacher`
(`id`, `salary`, `sex`, `name`)
VALUES
(3, 6500, 2, '教师3');
INSERT INTO `teacher`
(`id`, `salary`, `sex`, `name`)
VALUES
(4, 7500, 1, '教师4');
INSERT INTO `teacher`
(`id`, `salary`, `sex`, `name`)
VALUES
(5, 8500, 2, '教师5');
sql语句如下
drop PROCEDURE if exists find_teacher;
create PROCEDURE find_teacher(in tid int,out type varchar(10)) begin
declare teacher_salary int;
select salary into teacher_salary from teacher where id = tid;
IF teacher_salary > 5000 THEN
set type = '土豪';
ELSEif teacher_salary <= 5000 and teacher_salary >= 1500 then
set type = '马马虎虎';
elseif teacher_salary < 1500 then
set type = 'low 逼';
elseif teacher_salary is null then
set type = '查无此人!!!';
END IF;
end;
call find_teacher(6,@type);
select @type;
image.png
再举一个例子
成绩大于90, 学霸, 60到90之间, 继续努力, 小于60, 学渣
drop PROCEDURE if exists 评分;
create procedure 评分(in 分数 int)begin
if
分数 >= 90 then select '学霸';
elseif 分数 >= 60 and 分数 < 90 then select '继续加油';
else select '学渣';
end if;
end;
call 评分(97);
image.png
再再举一个例子
等公交, 车来了, 上车, 快来了, 继续等, 其他情况, 走起
drop PROCEDURE if exists 等公交;
create procedure 等公交(in 状态 char(10))begin
if
状态 = '来了' then select '上公交';
elseif 状态 = '快来了' then select '等公交';
else select '走起';
end if;
end;
call 等公交('快来了');
image.png
case
同样是分支结构, case既可以处理固定的值, 也可以处理范围
原来我们是用
1
代表男性,2
代表女性, 现在我想在查询的时候, 直接把1
转换成男性, 把2
转变成女性
原来的结果是这样的...
image.png
下面开始写sql语句
DROP PROCEDURE IF EXISTS select_teacher;
CREATE PROCEDURE select_teacher ( ) BEGIN
SELECT id, salary,
CASE sex
WHEN 1 THEN '男性'
WHEN 2 THEN '女性'
END AS 'sex',
name FROM teacher;
END;
CALL select_teacher ( );
image.png
现在我们使用case, 再来改写一下之前的if else...
DROP PROCEDURE IF EXISTS select_teacher;
CREATE PROCEDURE select_teacher() BEGIN
SELECT id, salary,
CASE sex
WHEN 1 THEN '男性'
WHEN 2 THEN '女性'
END AS 'sex',
CASE
WHEN salary > 5000 THEN '土豪'
WHEN salary >= 1500 AND salary <= 5000 THEN '马马虎虎'
WHEN salary < 1500 THEN 'low 逼'
END AS `type`
FROM teacher;
END;
CALL select_teacher();
image.png
循环 loop, while, repeat
下面, 我们使用三种循环, 分别输出10遍"我爱你"
loop
drop PROCEDURE if exists love;
create PROCEDURE love() begin
declare num int default 0;
myloop:loop
set num = num + 1;
if num > 10 then
leave myloop;
end if;
select num;
select '我爱你';
end loop;
end;
call love();
image.png
while
drop PROCEDURE if exists love;
create PROCEDURE love() begin
declare num int default 0;
while num < 10 do
set num = num + 1;
select num;
select '我爱你';
end while;
end;
call love();
image.png
repeat
drop PROCEDURE if exists love;
create PROCEDURE love() begin
declare num int default 0;
repeat
set num = num + 1;
select num;
select '我爱你';
until num > 9 end repeat;
end;
call love();
image.png
女朋友不满意, 还要你用三种循环输出10遍我错了
while do
drop procedure if exists 我错了;
create procedure 我错了() begin
declare 计数 int default 0;
while
计数< 10
do
select 计数;
select '我错了...';
set 计数 = 计数 + 1;
end while;
end;
call 我错了();
loop
drop procedure if exists 我错了;
create procedure 我错了() begin
declare 计数 int default 0;
hello:loop
select 计数;
select '我错了...';
set 计数 = 计数 + 1;
if 计数 >= 10 then leave hello;
end if;
end loop;
end;
call 我错了();
repeat until
drop procedure if exists 我错了;
create procedure 我错了() begin
declare 计数 int default 0;
repeat
select 计数;
select '我错了...';
set 计数 = 计数 + 1;
until
计数 >= 10
end repeat;
end;
call 我错了();
iterate/leave
相当于 continue 和 break
仅适用于循环(loop
,repeat
,while
)
跳过和中断
循环输出1到11, 逢5过
drop PROCEDURE if exists test;
create PROCEDURE test() begin
declare x int default 0;
myloop:loop
set x = x + 1;
if x % 5 = 0 then ITERATE myloop; end if;
select x;
if x> 10 then leave myloop; end if;
end loop;
end;
call test();
image.png
今天的小作业(如需答案请私信...)
使用
while
,repeat
,loop
三种方式, 计算从1加到100
提前告诉你, 结果是5050
所谓从1加到100, 就是... 1 + 2 + 3 + 4 + 5 + 6 + 7 + 8 + 9 + 10 + 11 + 12 + 13 + 14 + 15 + 16 + 17 + 18 + 19 + 20 + 21 + 22 + 23 + 24 + 25 + 26 + 27 + 28 + 29 + 30 + 31 + 32 + 33 + 34 + 35 + 36 + 37 + 38 + 39 + 40 + 41 + 42 + 43 + 44 + 45 + 46 + 47 + 48 + 49 + 50 + 51 + 52 + 53 + 54 + 55 + 56 + 57 + 58 + 59 + 60 + 61 + 62 + 63 + 64 + 65 + 66 + 67 + 68 + 69 + 70 + 71 + 72 + 73 + 74 + 75 + 76 + 77 + 78 + 79 + 80 + 81 + 82 + 83 + 84 + 85 + 86 + 87 + 88 + 89 + 90 + 91 + 92 + 93 + 94 + 95 + 96 + 97 + 98 + 99 + 100
也可以试试从1加到1000... 1 + 2 + 3 + 4 + 5 + 6 + 7 + 8 + 9 + 10 + 11 + 12 + 13 + 14 + 15 + 16 + 17 + 18 + 19 + 20 + 21 + 22 + 23 + 24 + 25 + 26 + 27 + 28 + 29 + 30 + 31 + 32 + 33 + 34 + 35 + 36 + 37 + 38 + 39 + 40 + 41 + 42 + 43 + 44 + 45 + 46 + 47 + 48 + 49 + 50 + 51 + 52 + 53 + 54 + 55 + 56 + 57 + 58 + 59 + 60 + 61 + 62 + 63 + 64 + 65 + 66 + 67 + 68 + 69 + 70 + 71 + 72 + 73 + 74 + 75 + 76 + 77 + 78 + 79 + 80 + 81 + 82 + 83 + 84 + 85 + 86 + 87 + 88 + 89 + 90 + 91 + 92 + 93 + 94 + 95 + 96 + 97 + 98 + 99 + 100 + 101 + 102 + 103 + 104 + 105 + 106 + 107 + 108 + 109 + 110 + 111 + 112 + 113 + 114 + 115 + 116 + 117 + 118 + 119 + 120 + 121 + 122 + 123 + 124 + 125 + 126 + 127 + 128 + 129 + 130 + 131 + 132 + 133 + 134 + 135 + 136 + 137 + 138 + 139 + 140 + 141 + 142 + 143 + 144 + 145 + 146 + 147 + 148 + 149 + 150 + 151 + 152 + 153 + 154 + 155 + 156 + 157 + 158 + 159 + 160 + 161 + 162 + 163 + 164 + 165 + 166 + 167 + 168 + 169 + 170 + 171 + 172 + 173 + 174 + 175 + 176 + 177 + 178 + 179 + 180 + 181 + 182 + 183 + 184 + 185 + 186 + 187 + 188 + 189 + 190 + 191 + 192 + 193 + 194 + 195 + 196 + 197 + 198 + 199 + 200 + 201 + 202 + 203 + 204 + 205 + 206 + 207 + 208 + 209 + 210 + 211 + 212 + 213 + 214 + 215 + 216 + 217 + 218 + 219 + 220 + 221 + 222 + 223 + 224 + 225 + 226 + 227 + 228 + 229 + 230 + 231 + 232 + 233 + 234 + 235 + 236 + 237 + 238 + 239 + 240 + 241 + 242 + 243 + 244 + 245 + 246 + 247 + 248 + 249 + 250 + 251 + 252 + 253 + 254 + 255 + 256 + 257 + 258 + 259 + 260 + 261 + 262 + 263 + 264 + 265 + 266 + 267 + 268 + 269 + 270 + 271 + 272 + 273 + 274 + 275 + 276 + 277 + 278 + 279 + 280 + 281 + 282 + 283 + 284 + 285 + 286 + 287 + 288 + 289 + 290 + 291 + 292 + 293 + 294 + 295 + 296 + 297 + 298 + 299 + 300 + 301 + 302 + 303 + 304 + 305 + 306 + 307 + 308 + 309 + 310 + 311 + 312 + 313 + 314 + 315 + 316 + 317 + 318 + 319 + 320 + 321 + 322 + 323 + 324 + 325 + 326 + 327 + 328 + 329 + 330 + 331 + 332 + 333 + 334 + 335 + 336 + 337 + 338 + 339 + 340 + 341 + 342 + 343 + 344 + 345 + 346 + 347 + 348 + 349 + 350 + 351 + 352 + 353 + 354 + 355 + 356 + 357 + 358 + 359 + 360 + 361 + 362 + 363 + 364 + 365 + 366 + 367 + 368 + 369 + 370 + 371 + 372 + 373 + 374 + 375 + 376 + 377 + 378 + 379 + 380 + 381 + 382 + 383 + 384 + 385 + 386 + 387 + 388 + 389 + 390 + 391 + 392 + 393 + 394 + 395 + 396 + 397 + 398 + 399 + 400 + 401 + 402 + 403 + 404 + 405 + 406 + 407 + 408 + 409 + 410 + 411 + 412 + 413 + 414 + 415 + 416 + 417 + 418 + 419 + 420 + 421 + 422 + 423 + 424 + 425 + 426 + 427 + 428 + 429 + 430 + 431 + 432 + 433 + 434 + 435 + 436 + 437 + 438 + 439 + 440 + 441 + 442 + 443 + 444 + 445 + 446 + 447 + 448 + 449 + 450 + 451 + 452 + 453 + 454 + 455 + 456 + 457 + 458 + 459 + 460 + 461 + 462 + 463 + 464 + 465 + 466 + 467 + 468 + 469 + 470 + 471 + 472 + 473 + 474 + 475 + 476 + 477 + 478 + 479 + 480 + 481 + 482 + 483 + 484 + 485 + 486 + 487 + 488 + 489 + 490 + 491 + 492 + 493 + 494 + 495 + 496 + 497 + 498 + 499 + 500 + 501 + 502 + 503 + 504 + 505 + 506 + 507 + 508 + 509 + 510 + 511 + 512 + 513 + 514 + 515 + 516 + 517 + 518 + 519 + 520 + 521 + 522 + 523 + 524 + 525 + 526 + 527 + 528 + 529 + 530 + 531 + 532 + 533 + 534 + 535 + 536 + 537 + 538 + 539 + 540 + 541 + 542 + 543 + 544 + 545 + 546 + 547 + 548 + 549 + 550 + 551 + 552 + 553 + 554 + 555 + 556 + 557 + 558 + 559 + 560 + 561 + 562 + 563 + 564 + 565 + 566 + 567 + 568 + 569 + 570 + 571 + 572 + 573 + 574 + 575 + 576 + 577 + 578 + 579 + 580 + 581 + 582 + 583 + 584 + 585 + 586 + 587 + 588 + 589 + 590 + 591 + 592 + 593 + 594 + 595 + 596 + 597 + 598 + 599 + 600 + 601 + 602 + 603 + 604 + 605 + 606 + 607 + 608 + 609 + 610 + 611 + 612 + 613 + 614 + 615 + 616 + 617 + 618 + 619 + 620 + 621 + 622 + 623 + 624 + 625 + 626 + 627 + 628 + 629 + 630 + 631 + 632 + 633 + 634 + 635 + 636 + 637 + 638 + 639 + 640 + 641 + 642 + 643 + 644 + 645 + 646 + 647 + 648 + 649 + 650 + 651 + 652 + 653 + 654 + 655 + 656 + 657 + 658 + 659 + 660 + 661 + 662 + 663 + 664 + 665 + 666 + 667 + 668 + 669 + 670 + 671 + 672 + 673 + 674 + 675 + 676 + 677 + 678 + 679 + 680 + 681 + 682 + 683 + 684 + 685 + 686 + 687 + 688 + 689 + 690 + 691 + 692 + 693 + 694 + 695 + 696 + 697 + 698 + 699 + 700 + 701 + 702 + 703 + 704 + 705 + 706 + 707 + 708 + 709 + 710 + 711 + 712 + 713 + 714 + 715 + 716 + 717 + 718 + 719 + 720 + 721 + 722 + 723 + 724 + 725 + 726 + 727 + 728 + 729 + 730 + 731 + 732 + 733 + 734 + 735 + 736 + 737 + 738 + 739 + 740 + 741 + 742 + 743 + 744 + 745 + 746 + 747 + 748 + 749 + 750 + 751 + 752 + 753 + 754 + 755 + 756 + 757 + 758 + 759 + 760 + 761 + 762 + 763 + 764 + 765 + 766 + 767 + 768 + 769 + 770 + 771 + 772 + 773 + 774 + 775 + 776 + 777 + 778 + 779 + 780 + 781 + 782 + 783 + 784 + 785 + 786 + 787 + 788 + 789 + 790 + 791 + 792 + 793 + 794 + 795 + 796 + 797 + 798 + 799 + 800 + 801 + 802 + 803 + 804 + 805 + 806 + 807 + 808 + 809 + 810 + 811 + 812 + 813 + 814 + 815 + 816 + 817 + 818 + 819 + 820 + 821 + 822 + 823 + 824 + 825 + 826 + 827 + 828 + 829 + 830 + 831 + 832 + 833 + 834 + 835 + 836 + 837 + 838 + 839 + 840 + 841 + 842 + 843 + 844 + 845 + 846 + 847 + 848 + 849 + 850 + 851 + 852 + 853 + 854 + 855 + 856 + 857 + 858 + 859 + 860 + 861 + 862 + 863 + 864 + 865 + 866 + 867 + 868 + 869 + 870 + 871 + 872 + 873 + 874 + 875 + 876 + 877 + 878 + 879 + 880 + 881 + 882 + 883 + 884 + 885 + 886 + 887 + 888 + 889 + 890 + 891 + 892 + 893 + 894 + 895 + 896 + 897 + 898 + 899 + 900 + 901 + 902 + 903 + 904 + 905 + 906 + 907 + 908 + 909 + 910 + 911 + 912 + 913 + 914 + 915 + 916 + 917 + 918 + 919 + 920 + 921 + 922 + 923 + 924 + 925 + 926 + 927 + 928 + 929 + 930 + 931 + 932 + 933 + 934 + 935 + 936 + 937 + 938 + 939 + 940 + 941 + 942 + 943 + 944 + 945 + 946 + 947 + 948 + 949 + 950 + 951 + 952 + 953 + 954 + 955 + 956 + 957 + 958 + 959 + 960 + 961 + 962 + 963 + 964 + 965 + 966 + 967 + 968 + 969 + 970 + 971 + 972 + 973 + 974 + 975 + 976 + 977 + 978 + 979 + 980 + 981 + 982 + 983 + 984 + 985 + 986 + 987 + 988 + 989 + 990 + 991 + 992 + 993 + 994 + 995 + 996 + 997 + 998 + 999 + 1000
网友评论