热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【原创】MySQL模拟PostgreSQLgenerate_series表函数

2019独角兽企业重金招聘Python工程师标准PostgreSQL提供了一个很强大的造数据的函数generate_series,基于CommonTableEx



2019独角兽企业重金招聘Python工程师标准>>> hot3.png



PostgreSQL 提供了一个很强大的造数据的函数generate_series,基于Common Table Expression。  


MySQL 没有复杂的应用程序类型,该如何实现这样的功能呢? 我想到的三种方法如下:


1. 用存储过程来做。 缺点是写好多数据库不擅长的应用逻辑。


2. 我们想到MySQL提供了SESSION 变量这样的特性, 可以很方便的完成同样的功能。


3. MariaDB 提供了一种sequence 引擎,也可以方便的做这件事情。




第一种我就不实现了, 我来举例说明后两种。




表结构如下:
ytt[love]>show create table test_series;
+-------------+-------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+-------------+-------------------------------------------------------------------------------------------------------------------------+
| test_series | CREATE TABLE `test_series` (
`id` int(11) NOT NULL,
`log_date` date NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1 |
+-------------+-------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
对应的PostgreSQL 运算结果:
t_girl=# insert into test_series select seq, current_date - '1 day'::interval*seq from generate_series(1,20) as g(seq);
INSERT 0 20
t_girl=# select * from test_series;
id | log_date
----+------------
1 | 2014-03-02
2 | 2014-03-01
3 | 2014-02-28
4 | 2014-02-27
5 | 2014-02-26
6 | 2014-02-25
7 | 2014-02-24
8 | 2014-02-23
9 | 2014-02-22
10 | 2014-02-21
11 | 2014-02-20
12 | 2014-02-19
13 | 2014-02-18
14 | 2014-02-17
15 | 2014-02-16
16 | 2014-02-15
17 | 2014-02-14
18 | 2014-02-13
19 | 2014-02-12
20 | 2014-02-11
(20 rows)



第一: SESSION 变量。




MySQL 的SESSION 变量来变相实现的话,需要一个种子库。




以下存储过程生成种子库。
DELIMITER $$
USE `t_girl`$$
DROP PROCEDURE IF EXISTS `sp_seed`$$
CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_seed`(
IN f_num INT UNSIGNED
)
BEGIN
DROP TABLE IF EXISTS tmp_seed;
CREATE TEMPORARY TABLE tmp_seed (id INT);
BEGIN
DECLARE i INT;
SET i = 1;
WHILE i <&#61; f_num DO
INSERT INTO tmp_seed VALUES (i);
SET i &#61; i &#43; 1;
END WHILE;
END;
END$$
DELIMITER ;
生成20个种子库
ytt[love]>call sp_seed(20);
Query OK, 1 row affected (0.15 sec)
现在利用刚才的种子库以及SESSION 变量来实现。
ytt[love]>insert into test_series select &#64;a :&#61; &#64;a &#43; 1 as seq, date_sub(current_date(), interval &#64;a day) from tmp_seed,(select &#64;a:&#61;0) as seq;
Query OK, 20 rows affected (0.02 sec)
Records: 20 Duplicates: 0 Warnings: 0
ytt[love]>select * from test_series;
&#43;----&#43;------------&#43;
| id | log_date |
&#43;----&#43;------------&#43;
| 1 | 2014-03-02 |
| 2 | 2014-03-01 |
| 3 | 2014-02-28 |
| 4 | 2014-02-27 |
| 5 | 2014-02-26 |
| 6 | 2014-02-25 |
| 7 | 2014-02-24 |
| 8 | 2014-02-23 |
| 9 | 2014-02-22 |
| 10 | 2014-02-21 |
| 11 | 2014-02-20 |
| 12 | 2014-02-19 |
| 13 | 2014-02-18 |
| 14 | 2014-02-17 |
| 15 | 2014-02-16 |
| 16 | 2014-02-15 |
| 17 | 2014-02-14 |
| 18 | 2014-02-13 |
| 19 | 2014-02-12 |
| 20 | 2014-02-11 |
&#43;----&#43;------------&#43;
20 rows in set (0.00 sec)



第二&#xff1a;


MySQL(MariaDB ) 提供了一个序列引擎&#xff0c;可以有这样的功能。


由于MySQL 没有表函数功能&#xff0c;所以如果要造多个字段的数据&#xff0c;就得用JOIN来实现了。




ytt[love]>insert into test_series select s1.seq,date_sub(current_date(),interval s2.seq day) as date from seq_1_to_20 as s1, seq_1_to_20 as s2 where s1.seq &#61; s2.seq;
Query OK, 20 rows affected (0.07 sec)
Records: 20 Duplicates: 0 Warnings: 0
ytt[love]>select * from test_series;
&#43;----&#43;------------&#43;
| id | log_date |
&#43;----&#43;------------&#43;
| 1 | 2014-03-02 |
| 2 | 2014-03-01 |
| 3 | 2014-02-28 |
| 4 | 2014-02-27 |
| 5 | 2014-02-26 |
| 6 | 2014-02-25 |
| 7 | 2014-02-24 |
| 8 | 2014-02-23 |
| 9 | 2014-02-22 |
| 10 | 2014-02-21 |
| 11 | 2014-02-20 |
| 12 | 2014-02-19 |
| 13 | 2014-02-18 |
| 14 | 2014-02-17 |
| 15 | 2014-02-16 |
| 16 | 2014-02-15 |
| 17 | 2014-02-14 |
| 18 | 2014-02-13 |
| 19 | 2014-02-12 |
| 20 | 2014-02-11 |
&#43;----&#43;------------&#43;
20 rows in set (0.00 sec)





本文出自 “上帝&#xff0c;咱们不见不散&#xff01;” 博客&#xff0c;请务必保留此出处http://yueliangdao0608.blog.51cto.com/397025/1369057







转载于:https://my.oschina.net/u/585111/blog/219454



推荐阅读
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • ALTERTABLE通过更改、添加、除去列和约束,或者通过启用或禁用约束和触发器来更改表的定义。语法ALTERTABLEtable{[ALTERCOLUMNcolu ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • Python SQLAlchemy库的使用方法详解
    本文详细介绍了Python中使用SQLAlchemy库的方法。首先对SQLAlchemy进行了简介,包括其定义、适用的数据库类型等。然后讨论了SQLAlchemy提供的两种主要使用模式,即SQL表达式语言和ORM。针对不同的需求,给出了选择哪种模式的建议。最后,介绍了连接数据库的方法,包括创建SQLAlchemy引擎和执行SQL语句的接口。 ... [详细]
  • 本文主要复习了数据库的一些知识点,包括环境变量设置、表之间的引用关系等。同时介绍了一些常用的数据库命令及其使用方法,如创建数据库、查看已存在的数据库、切换数据库、创建表等操作。通过本文的学习,可以加深对数据库的理解和应用能力。 ... [详细]
  • 在Oracle11g以前版本中的的DataGuard物理备用数据库,可以以只读的方式打开数据库,但此时MediaRecovery利用日志进行数据同步的过 ... [详细]
  • MySQL语句大全:创建、授权、查询、修改等【MySQL】的使用方法详解
    本文详细介绍了MySQL语句的使用方法,包括创建用户、授权、查询、修改等操作。通过连接MySQL数据库,可以使用命令创建用户,并指定该用户在哪个主机上可以登录。同时,还可以设置用户的登录密码。通过本文,您可以全面了解MySQL语句的使用方法。 ... [详细]
  • 合并列值-合并为一列问题需求:createtabletab(Aint,Bint,Cint)inserttabselect1,2,3unionallsel ... [详细]
  • MySQL插入数据的四种方式及安全性分析
    本文介绍了MySQL插入数据的四种方式:插入完整的行、插入行的一部分、插入多行和插入查询结果,并对其安全性进行了分析。在插入行时,应注意字段的定义和赋值,以提高安全性。同时指出了使用insert语句的不安全性,应尽量避免使用。建议在表中定义相关字段,并根据定义的字段赋予相应的值,以增加插入操作的安全性。 ... [详细]
  • 本文介绍了解决二叉树层序创建问题的方法。通过使用队列结构体和二叉树结构体,实现了入队和出队操作,并提供了判断队列是否为空的函数。详细介绍了解决该问题的步骤和流程。 ... [详细]
  • 本文介绍了C函数ispunct()的用法及示例代码。ispunct()函数用于检查传递的字符是否是标点符号,如果是标点符号则返回非零值,否则返回零。示例代码演示了如何使用ispunct()函数来判断字符是否为标点符号。 ... [详细]
  • 开发笔记:select from具体执行相关知识介绍及案例分析
    本文由编程笔记小编整理,主要介绍了select from具体执行相关的知识,包括数据插入、查询最小rowID、查询每个重复名字的最小rowID、删除重复数据等操作,并提供了案例分析。希望对读者有一定的参考价值。 ... [详细]
author-avatar
ekuuu
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有