在做项目的时候,遇到了需要在数据库中给字段默认值的问题,默认值需要显示的是当前年份,给大家分享下:
找了一些资料后,感觉这个方法很适用:
将数据类型改成了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"单词。