首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在PosrgreSQL/SQL中使用结果子串

如何在PosrgreSQL/SQL中使用结果子串
EN

Stack Overflow用户
提问于 2014-03-24 16:51:02
回答 2查看 152关注 0票数 0

我不知道如何正确地命名这种语法。我得到了一个包含列A的表(比如T),其中以USER-YYYY-MMDD格式存储条目。我想提取A列的年份部分(YYYY部分)大于2010的所有行。例如。

代码语言:javascript
复制
TABLE T
+----------------+
|        A       |
+----------------+
| USER-2011-1234*|
| USER-1992-1923 |
| USER-2014-1234*|
+----------------+

(*)是我想要的:YYYY部分大于2010。SQL应该是这样的,但我不知道如何用PostgreSQL来表达它。

代码语言:javascript
复制
 SELECT * FROM T WHERE A[5-8] > 2010

谢谢!

EN

回答 2

Stack Overflow用户

发布于 2014-03-24 16:56:17

代码语言:javascript
复制
select *
from t
where to_number(substr(a, 6, 4)) > 2010;

请注意,如果字符串不能转换为数字,则his将失败并显示错误

手册中有更多详细信息:http://www.postgresql.org/docs/current/static/functions-string.html

顺便说一句:在单个列中存储多个信息是一个糟糕的设计。您应该将用户名和日期存储在两个不同的列中。此外,将日期存储为varchar也不是一个好主意。日期应存储为date格式,而不是varchar格式

票数 3
EN

Stack Overflow用户

发布于 2014-03-24 16:59:41

试着这样做

代码语言:javascript
复制
select *
from t
where  substring(a::text from 6 for 4)::integer > 2010;
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22604696

复制
相关文章

相似问题

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