将 varchar 强制转换为日期

发布于 2024-10-22 00:35:11 字数 391 浏览 1 评论 0原文

我在一个小项目中使用 H2 数据库,所有字段都是 varchar

用于查询,我必须将字符串转换为日期,所以我尝试了

SELECT * FROM USER WHERE cast(DATE_CONTRACT AS DATE)  >  '2005-02-21' 

,但出现错误

代码:

错误代码 90009,SQL 状态 90009: 无法解析日期常量 “2011-02-21-15.22.07”,原因: “java.lang.NumberFormatException:对于 输入字符串:“”21-15.22.07“””;

有什么想法吗?

谢谢

i use a H2 database for a small project, all field are varchar

for a query, i must convert a string to date so i tried

SELECT * FROM USER WHERE cast(DATE_CONTRACT AS DATE)  >  '2005-02-21' 

but there are an error

Code :

Error code 90009, SQL state 90009:
Cannot parse date constant
"2011-02-21-15.22.07", cause:
"java.lang.NumberFormatException: For
input string: ""21-15.22.07""";

any idea?

thanks

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

小红帽 2024-10-29 00:35:11

您必须使用 parsedatetime() 才能将字符数据“转换”为日期。

http://h2database.com/html/functions.html#parsedatetime

像这样:

SELECT * 
FROM USER 
WHERE parsedatetime(DATE_CONTRACT, 'yyyy-MM-dd-HH.mm.ss')  > DATE '2005-02-21' 

永远不要将日期、时间戳或数字存储为字符数据的另一个好理由

You have to use parsedatetime() in order to "cast" your character data to a date.

http://h2database.com/html/functions.html#parsedatetime

Something like this:

SELECT * 
FROM USER 
WHERE parsedatetime(DATE_CONTRACT, 'yyyy-MM-dd-HH.mm.ss')  > DATE '2005-02-21' 

Another good reason to never store dates, timestamps or numbers as character data

枫以 2024-10-29 00:35:11

当然,您可以使用内置函数 PARSEDATETIME ,如下所示:

CREATE TABLE USER(DATE_CONTRACT VARCHAR);
INSERT INTO USER VALUES('2011-02-21-15.22.07');
SELECT * FROM USER 
WHERE PARSEDATETIME(DATE_CONTRACT, 'yyyy-MM-dd-HH.mm.ss') > DATE '2005-02-21';

但我想以更标准的格式存储时间戳会更有意义,这样就不需要特殊的解析。示例:

CREATE TABLE USER(DATE_CONTRACT TIMESTAMP);
INSERT INTO USER VALUES('2011-02-21 15:22:07');
SELECT * FROM USER 
WHERE DATE_CONTRACT > DATE '2005-02-21';

H2 支持 JDBC 支持的格式,以及 ISO 8601

Of course you could use the built-in function PARSEDATETIME as follows:

CREATE TABLE USER(DATE_CONTRACT VARCHAR);
INSERT INTO USER VALUES('2011-02-21-15.22.07');
SELECT * FROM USER 
WHERE PARSEDATETIME(DATE_CONTRACT, 'yyyy-MM-dd-HH.mm.ss') > DATE '2005-02-21';

But I guess it would make more sense to store the timestamp in a more standard format, so that no special parsing is required. Example:

CREATE TABLE USER(DATE_CONTRACT TIMESTAMP);
INSERT INTO USER VALUES('2011-02-21 15:22:07');
SELECT * FROM USER 
WHERE DATE_CONTRACT > DATE '2005-02-21';

H2 supports the format supported by JDBC, plus ISO 8601.

如此安好 2024-10-29 00:35:11

为什么要转换为日期?如果 DATE_CONTRACT 使用一致的 CHAR(19),您可以:

SELECT * 
FROM USER 
WHERE DATE_CONTRACT >= '2005-02-22-00.00.00'
;

如果我错了,请纠正我,但如果 DATE_CONTRACT 上有索引,这将比转换为日期/日期时间更快。

Why convert to date? If DATE_CONTRACT uses a consistent CHAR(19), you can:

SELECT * 
FROM USER 
WHERE DATE_CONTRACT >= '2005-02-22-00.00.00'
;

Correct me if I'm wrong but if there is an index on DATE_CONTRACT, this will be faster than converting to date/datetime.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文