首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何创建MySQL函数,通过处理已有的date列来创建一个新的quarter列?

如何创建MySQL函数,通过处理已有的date列来创建一个新的quarter列?
EN

Stack Overflow用户
提问于 2016-05-09 19:03:39
回答 1查看 25关注 0票数 1

我有一个列日期,如下所示:

代码语言:javascript
复制
+-----------+
|   Date    |
+-----------+
|  20140611 |
|  20150119 |
|  20150922 |
|  20160310 |
+-----------+

它是一个YYYYMMDD格式的字符串。

我想创建一个名为Quarter的新列,如下所示:

代码语言:javascript
复制
+-----------+-------------+
|   Date    |   Quarter   |
+-----------+-------------+
|  20140611 |  Q2-2014    |
|  20150119 |  Q1-2015    |
|  20150922 |  Q3-2015    |
|  20160310 |  Q3-2016    |
+-----------+-------------+

其中Quarter表示相应Date下降的季度。

这只是一个示例,但我实际上想知道如何编写一个函数,该函数可以应用于表的单个列,并在经过一些预定义的处理后创建一个新列。

EN

回答 1

Stack Overflow用户

发布于 2016-05-09 19:08:03

使用quarter函数

代码语言:javascript
复制
select `Date`, QUARTER(`date`) as Quarter
from my_table ;

否则,如果您正在寻找用户定义的函数,则可以使用

代码语言:javascript
复制
CREATE FUNCTION hello_world(my_text TEXT)
    RETURNS TEXT
    LANGUAGE SQL -- This element is optional and will be omitted from    
    BEGIN
     RETURN CONCAT('Hello ', my_text);
   END;
    $$
  DELIMITER ;

然后

代码语言:javascript
复制
SELECT hello_world('Earth');

返回Hello Earth

http://dev.mysql.com/doc/refman/5.7/en/create-function-udf.html

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37114134

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档