SQL也疯狂:MySQL绘制简单几何图形(2013-04-12)
程序员文章站
2022-06-12 08:56:31
...
用SQL SELECT 语句而非存储过程来画基本几何图形,以加深对 SELECT 语句的理解。因为 SELECT 语句隐含了一个或多个循环,看上去只是一个语句,其实包含了一个完整的程序所包含的顺序、分支、循环,因此不必用存储过程就能实现一般的程序的功能 需要有一个表
- 用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
- 画横线
语句
SET @w := 24; # 宽 SELECT repeat("*", @w) AS line;
结果+--------------------------+ | line | +--------------------------+ | ************************ | +--------------------------+
- 画竖线
语句
SET @h := 12; # 高 SET @y := 0; # y 座标 SELECT "*" AS line FROM number WHERE @y 结果
+------+ | line | +------+ | * | | * | | * | | * | | * | | * | | * | | * | | * | | * | | * | | * | +------+
- 画斜线
语句
SET @h := 12; # 高 SET @y := 0; # y 座标 SET @rate := 2; # x y 座标比例(斜率倒数) SELECT lpad("*", @y * @rate, " ") AS line FROM number WHERE @y 结果
+--------------------------+ | line | +--------------------------+ | * | | * | | * | | * | | * | | * | | * | | * | | * | | * | | * | | * | +--------------------------+
- 画XX
语句
SET @h := 12; # 高 SET @w := 24; # 宽 SET @y := 0; # y 座标 SET @rate := @w / @h; # x y 座标比例(斜率倒数) SELECT X FROM ( SELECT concat(lpad("*", @y * @rate - 1, " "), repeat(" ", @w - 2 * @y * @rate - 2 + 1), IF(@w - 2 * @y * @rate - 2 + 1 "", "