更改一个没有主键的oracle表中并不是完全相同的其中一条语句

最近在项目中遇到一个oracle表修改的问题,但是想了好久才相出来,感觉此问题 应该很多情况都会用到的,问题大概是这样的

一个oracle数据库表tab1中有这些数据
storeid   title  name   number  isread
1           www  qqq     1           0
1           www  qqq     2           0
1           www  qqq     3           0
1           www  qqq     4           0
2           eee     rrr      h          0
2           eee     rrr      j           0
2           eee     rrr      k           0
3           aaa    bbb     c           0
3           aaa    bbb     d           0
.....
将近一万条类似的数据
请写一条update的sql把表中的isread字段置为1(要求storeid相同的数据只需要其中的任意一条的isread置为1,其他还是0)
这个表里面没有主键,每条数据也不可能完全相同,只不过相同ID的这些数据里面好多字段是相同的

针对这个问题:
1:我第一想的是用sql修改,但是想了很久没相出来,所以后来选择的是jdbc ,查询出一个可编辑的rowset 如果storeid和上一条一样则不修改,不一样则修改,很容易就解决了这个问题,只是jdbc修改数据库的时候可能慢点
2:当我解决完了该问题的时候,我并不气馁,有事没事儿的时候也会想一下这个问题,终于某日终于想出了这条sql语句可以修改
 update tab1 t1 set t1.isread=1
where t1.rowid in
(
select max(t2.rowid) from tab1 t2
group by t2.storeid,t2.isread
)
这是结果 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值