视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
mysql根据时间排序,更新某字段值
2020-11-09 09:19:03 责编:小采
文档


mysqlsql数据库

现在有一张表,表中已经有4000条数据,其中有一个字段为 order_id,
另一字段为pub_time ,原来order_id 是根据数据插入顺序自动+1的,现在我想根据pub_time递增,
更新order_id的值为递增,有什么好办法吗???不是更新新加的数据,是更新表中现有的4000条数据

回复内容:

mysql库对吧,直接上脚本:
update Table t
inner join
(SELECT @rownum := @rownum + 1 AS rank, t.order_id
FROM Table t, (SELECT @rownum := 5000) r
order by pub_time asc) c on c.order_id = t.order_id
set t.order_id = c.rank;

基本逻辑就是先根据pub_time排序并生成序号,然后更新到原表。
这里有个要注意的是,为了避免在更新过程中产生order_id主键冲突,rank的初始值最好设大点,我这里rowrum初始为5000。

sql命令不是很熟悉,不知道能不能行,可以的话,用php写个脚本应该可以

也就是说你的order_id是在插入数据时设置的为自增喽,现在你想根据pub_time的值重新排列数据,并且重新更新order_id的值对吧。?

如果是我表达的这个意思,你应该用代码去解决问题,而不是用sql语句。至少我是没有想出来能用一条update语句解决。

没明白你的意思。你是想根据pub_time递增的值 来 更新order_id的值?

下载本文
显示全文
专题