本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《
阿里云开发者社区用户服务协议
》和
《
阿里云开发者社区知识产权保护指引
》。如果您发现本社区中有涉嫌抄袭的内容,填写
侵权投诉表单
进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
以上是表的两个字段,通过BirthDay字段的数据自动生成Age字段
Age字段的公式如下:
(case when (datediff(year,[BirthDay],getdate()) <> 0) then (ltrim(datediff(year,[BirthDay],getdate())) + '岁') else (case when (datediff(month,[BirthDay],getdate()) <> 0) then (ltrim(datediff(month,[BirthDay],getdate())) + '月') else (case when (datediff(day,[BirthDay],getdate()) <> 0) then (ltrim(datediff(day,[BirthDay],getdate())) + '天') else '' end) end) end)
这样子产生的数据就是通过填写的日期计算的。
下面是一个简单的SQL语句:
1 SELECT * ,
2 ( CASE WHEN ( DATEDIFF(year, [BirthDay], GETDATE()) <> 0 )
3 THEN ( LTRIM(DATEDIFF(year, [BirthDay], GETDATE())) + '岁' )
4 ELSE ( CASE WHEN ( DATEDIFF(month, [BirthDay], GETDATE()) <> 0 )
5 THEN ( LTRIM(DATEDIFF(month, [BirthDay], GETDATE()))
6 + '月' )
7 ELSE ( CASE WHEN ( DATEDIFF(day, [BirthDay],
8 GETDATE()) <> 0 )
9 THEN ( LTRIM(DATEDIFF(day, [BirthDay],
10 GETDATE())) + '天' )
11 ELSE ''
12 END )
13 END )
14 END )
15 FROM Test
以上是进行测试的代码