欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

SQL也疯狂:MySQL绘制简单几何图形(2013-04-12)

程序员文章站 2024-01-25 12:03:40
...

用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  
        
       
  1. 画横线 语句
    SET @w := 24;  # 宽 SELECT repeat("*", @w) AS line;
    
    结果
    +--------------------------+
    | line                     |
    +--------------------------+
    | ************************ |
    +--------------------------+
    
  2. 画竖线 语句
    SET @h := 12;  # 高
    SET @y := 0;   # y 座标 SELECT "*" AS line FROM number WHERE @y  
        
       
       
        
        结果 
        
        
        
    +------+
    | line |
    +------+
    | *    |
    | *    |
    | *    |
    | *    |
    | *    |
    | *    |
    | *    |
    | *    |
    | *    |
    | *    |
    | *    |
    | *    |
    +------+
    
  3. 画斜线 语句
    SET @h := 12;   # 高
    SET @y := 0;    # y 座标
    SET @rate := 2; # x y 座标比例(斜率倒数) SELECT lpad("*", @y * @rate, " ") AS line FROM number WHERE @y  
        
       
       
        
        结果 
        
        
        
    +--------------------------+
    | line                     |
    +--------------------------+
    |  *                       |
    |    *                     |
    |      *                   |
    |        *                 |
    |          *               |
    |            *             |
    |              *           |
    |                *         |
    |                  *       |
    |                    *     |
    |                      *   |
    |                        * |
    +--------------------------+
    
  4. 画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 "",  "