前言
- 用SQL SELECT 语句而非存储过程来画基本几何图形,以加深对 SELECT 语句的理解。因为 SELECT 语句隐含了一个或多个循环,看上去只是一个语句,其实包含了一个完整的程序所包含的顺序、分支、循环,因此不必用存储过程就能实现一般的程序的功能
准备数据
- 需要有一个表有 100 行以上的数据,数据是什么没关系,因为下面的语句已经避开使用数据库记录中的数据了。如果没有现成的就使用如下代码生成一个吧:
语句
DELIMITER ;; DROP PROCEDURE IF EXISTS test_num;; CREATE PROCEDURE test_num(MAX_COUNT INTEGER) BEGIN DECLARE i INTEGER; SET i = 0; DROP TABLE IF EXISTS number; CREATE TABLE number(num INT(10), PRIMARY KEY (num)); WHILE i < MAX_COUNT DO INSERT INTO number(num) VALUES (i); SET i = i + 1; END WHILE; END;; DELIMITER ; CALL test_num(100);
开始
- 画横线
语句
SET @w := 24; # 宽 SELECT repeat("*", @w) AS line;
结果+--------------------------+ | line | +--------------------------+ | ************************ | +--------------------------+
- 画竖线
语句
SET @h := 12; # 高 SET @y := 0; # y 座标 SELECT "*" AS line FROM number WHERE @y < @h and @y := @y + 1;
结果+------+ | line | +------+ | * | | * | | * | | * | | * | | * | | * | | * | | * | | * | | * | | * | +------+
- 画斜线
语句
SET @h := 12; # 高 SET @y := 0; # y 座标 SET @rate := 2; # x y 座标比例(斜率倒数) SELECT lpad("*", @y * @rate, " ") AS line FROM number WHERE @y < @h and @y := @y + 1;
结果+--------------------------+ | line | +--------------------------+ | * | | * | |