免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1882 | 回复: 2
打印 上一主题 下一主题

请教两个SQL语句 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-12-02 21:28 |只看该作者 |倒序浏览
请问两个修改语句
1。createtime是date类型,能否用一条语句将其中的年份字段修改,其它不动,比如将2008-12-1 06:07:00.0修改为2007-12-1 06:07:00.0
2。message字段是varchar字段内容基本上是“2008 *****************” ,能否用一条语句将2008修改为2007,其它不动

论坛徽章:
0
2 [报告]
发表于 2008-12-02 23:14 |只看该作者
解决了 方法如下
第二个
UPDATE
    tablename
SET
message= concat('2007',substr(message,5))

第一个
UPDATE
    tablename
SET
CREATETIME = to_date(concat(concat(concat(concat(concat(concat(concat(concat(concat(concat('2007','-'),to_char(CREATETIME ,'MM')),'-'),to_char(CREATETIME ,'DD')),' '),to_char(CREATETIME ME,'HH24')),':'),to_char(CREATETIME ,'Mi')),':'),to_char(CREATETIME ,'SS')),'yyyy-mm-dd hh24:mi:ss')

论坛徽章:
0
3 [报告]
发表于 2008-12-03 08:15 |只看该作者
1.  add_months(createdate,-12)
因为存在2008/02/29的问题,否则createdate-365也是可以的,比如2007改到2006年就可以createdate-365

2. 如果格式统一的话,都是“2008-12-1 06:07:00.0”的格式,用这个方法就可以:replace(message,'2008','2007')

[ 本帖最后由 doni 于 2008-12-3 08:21 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP