首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL是否可以在日期列中显示(仅显示)非日期字符串?

SQL是否可以在日期列中显示(仅显示)非日期字符串?
EN

Stack Overflow用户
提问于 2011-04-27 11:11:53
回答 3查看 188关注 0票数 0

我想知道,在日期列中没有日期时,是否可以显示"-“

因此,一个元组可能是{Dave,2011年7月13日},而另一个元组可能是{John,-}

编辑:感谢下面提出这个建议的人:

代码语言:javascript
复制
SELECT `ID`, COALESCE(CAST(`Graduation Date` AS CHAR), '-') FROM <table>

啊,真灵!

EN

回答 3

Stack Overflow用户

发布于 2011-04-27 11:15:25

使用COALESCE

代码语言:javascript
复制
SELECT name, COALESCE(date, '-')
FROM table

编辑:不知道它怎么可能不工作。示例:

代码语言:javascript
复制
SELECT COALESCE('2011-01-01', '-') //returns '2011-01-01'
SELECT COALESCE('', '-') //returns ''
SELECT COALESCE(NULL, '-') //returns '-'

尝试它们3条语句,您将看到返回的内容。

EDIT2:

代码语言:javascript
复制
SELECT name, IF(COALESCE(date, '-') = '', '-', date)
FROM table
票数 2
EN

Stack Overflow用户

发布于 2011-04-27 12:29:51

如果date列包含一些您希望以与NULL相同的方式处理的特殊日期(例如,0000-00-00),则可以尝试以下方法:

代码语言:javascript
复制
SELECT COALESCE(NULLIF(yourdatecolumn, '0000-00-00'), '-')

这实际上只是一种较短的写作方式:

代码语言:javascript
复制
SELECT CASE
         WHEN yourdatecolumn IS NULL OR yourdatecolumn = '0000-00-00' THEN '-'
         ELSE yourdatecolumn
       END
票数 1
EN

Stack Overflow用户

发布于 2011-04-27 11:16:12

代码语言:javascript
复制
SELECT ID, IF(GRADUATIONDATE IS NULL, '-', GRADUATIONDATE) FROM TABLE

or 

SELECT ID, IFNULL(GRADUATIONDATE,'-') FROM TABLE
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5803102

复制
相关文章

相似问题

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