• mysql在插入或更新的时候对一个字段赋递增值


    在我们有一个需求是更新某个表里面的某个字段,让这个字段变成一个递增的值,或者插入某个表中使得某些字段的值是递增的。下面我们来看看具体的操作:

    更改表字段为递增

    首先设置一个变量,初始值为任意数值,这里以0为例:

    set @num:=0;

    例如我们需要更新rank(排序)这个字段的值。我们可以这样处理

    update tablename set rank=(@num:= @num+1)

    添加主键

    同时也可以给一个没有主键的数据表添加主键,例如给表test新加字段id,对这个id字段进行递增操作,然后再设置为主键。

    SET @r:=0;
    UPDATE test SET id=(@r:=@r+1);

    插入递增数据

    如果要是向一个表里面插入数据,可以如下操作,例如,我想向临时表temp表中插入数据,并且保证temp中rank字段是递增的,写法如下:

    start TRANSACTION;
    SET @rank:= 20;
    INSERT into tbl_live_tab_relation(type, tab_id, relate_id, rank, source)
    SELECT 2,1, id, @rank:= @rank + 1, 0
    from tbl_live_room
    WHERE status=1 and id not in (
      SELECT relation.relate_id
    from tbl_live_tab_relation as relation
    WHERE relation.tab_id=1 AND relation.type=2
    )
    order by start_time DESC;
    COMMIT;
  • 相关阅读:
    xwalkview 替换掉webview 注意事项
    rsyslog Properties 属性:
    Basic Structure 基本结构:
    Crosswalk 集成到 Android Studio
    awk if 判断
    Important System Configuration 导入系统配置:
    Heap size check 堆大小检查
    Bootstrap Checks 抽样检查:
    Important Elasticsearch configuration 导入Elasticsearch 配置
    while 退出循环
  • 原文地址:https://www.cnblogs.com/duhuo/p/6386331.html
Copyright © 2020-2023  润新知