如何使用 t-sql 更新数据库中日期字段的部分数据(年?月?日?时?分?秒?)
嗯,从网上找到了一些内容,综合利用了sql server的一些内置方法
首先是 convert 方法:https://msdn.microsoft.com/zh-cn/library/ms187928.aspx
CONVERT(data_type(length),data_to_be_converted,style)
这个方法相当于是把日期数据格式化成字符串输出了。
然后是 stuff 方法:https://msdn.microsoft.com/zh-cn/library/ms188043.aspx
STUFF ( character_expression , start , length , replaceWith_expression )
这个方法是从第一个字符串的开始位置删除指定长度的字符;然后将第二个字符串插入到第一个字符串的开始位置。
就这样局部替换就好了
测试:
select top 1 addtime, convert(nvarchar(23),addtime,121), stuff(convert(nvarchar(23),addtime,121),1,4,'2012') from tbl_recordinfo
嗯,好像还挺好使的
下面是原帖:http://blog.csdn.net/yangbolg/article/details/18596311
--修改d表日期字段的年份
update d
set birth=STUFF(convert(nvarchar(23),birth,120),1,4,'2012')
--修改d表日期字段的月份
update d
set birth=STUFF(convert(nvarchar(23),birth,120),6,2,'3')
--修改d表日期字段的天数
update d
set birth=STUFF(convert(nvarchar(23),birth,120),9,2,'25')
--修改d表日期字段的小时数
update d
set birth =STUFF(convert(nvarchar(23),birth,120),12,2,'9')
--修改d表日期字段的分钟数
update d
set birth =STUFF(convert(nvarchar(23),birth,120),15,2,'15')
--修改d表日期字段的秒数
update d
set birth =STUFF(convert(nvarchar(23),birth,120),18,2,'30')
--修改d表日期字段的年份、小时
update d
set birth=Convert(datetime,stuff(STUFF(Convert(char,birth,120), 1,4, '2011'),12,2, '02'))
--修改表日期字段的年份
update d
set birth=dateadd(year,datediff(year,birth,'2016-01-01'),birth)
where year(birth)<>2012
--修改表日期字段的小时
update d
set birth=dateadd(hour,3,birth)
输了你,赢了世界又如何...
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!