在做项目的时候,遇到了需要在数据库中给字段默认值的问题,默认值需要显示的是当前年份,给大家分享下:
找了一些资料后,感觉这个方法很适用:
将数据类型改成了varchar,默认值设置为 convert(varchar(4),getdate(),120),这个方法读出的就是当前的年份
在得出这个结论之前,也尝试了许多未成功方法:
1,刚开始使用了datepart(year,getdate())这个函数,结果显示的是<不可识别数据>
2.后来用了year(getdate()),结果插入的数据是1905-07-07 00:00:00
在找资料过程中,顺便学习了下其他时间格式的设置方法:
select CONVERT(varchar, getdate(), 120 ) ----------------->>SQL语句
2004-09-12 11:06:08 -------------------------------------------->>显示结果(以下类同)
select replace(replace(replace(CONVERT(varchar, getdate(), 120 ),\''-\'',\''\''),\'' \'',\''\''),\'':\'',\''\'')
20040912110608
select CONVERT(varchar(12) , getdate(), 111 )
2004/09/12
select CONVERT(varchar(12) , getdate(), 112 )
20040912
select CONVERT(varchar(12) , getdate(), 102 )
2004.09.12
select CONVERT(varchar(12) , getdate(), 101 )
09/12/2004
select CONVERT(varchar(12) , getdate(), 103 )
12/09/2004
select CONVERT(varchar(12) , getdate(), 104 )
12.09.2004
select CONVERT(varchar(12) , getdate(), 105 )
12-09-2004
select CONVERT(varchar(12) , getdate(), 106 )
12 09 2004
select CONVERT(varchar(12) , getdate(), 107 )
09 12, 2004
select CONVERT(varchar(12) , getdate(), 108 )
11:06:08
select CONVERT(varchar(12) , getdate(), 109 )
09 12 2004 1
select CONVERT(varchar(12) , getdate(), 110 )
09-12-2004
select CONVERT(varchar(12) , getdate(), 111 )
2007-3-23
select CONVERT(varchar(12) , getdate(), 113 )
12 09 2004 1
select CONVERT(varchar(12) , getdate(), 114 )
11:06:08.177
设置默认值时去掉"select"单词。
本文介绍了在SQL Server中如何为时间类型字段设置默认值,特别是如何显示当前年份。通过将字段类型改为varchar并设置默认值为convert(varchar(4),getdate(),120),可以获取当前年份。同时,文章列举了多种日期格式转换的示例,如101到114的各种风格,展示了如何根据需求调整日期显示格式。"
111997318,10350186,SQL语法基础详解,"['数据库理论', 'SQL语法', '数据库操作']
1257

被折叠的 条评论
为什么被折叠?



