zoukankan      html  css  js  c++  java
  • sql 复杂自动编号错误批量修改方案

    [一篮饭特稀原创,转载请注明出自http://www.cnblogs.com/wanghafan/p/5133953.html

    前提:自动编号为18位,前4位是年份,中间10位是XXXX,最后四位是0001-9999的自动编号。

    问题:某天发现2016年自动编号后四位从0001-0081后变为7328-8530,出现编号错乱问题(原因未知待查)。但数据需要马上批量重置,否则后续编号将继续错误。

    方案:截取2016年份的前14位拼接后4位正确自动编号。实现如下:

    --查询2016年我司项目编号,查看后四位是否正确
    SELECT MyProjectNo,SUBSTRING(MyProjectNo,15,4) FROM dbo.ProjectT WHERE MyProjectNo LIKE '2016%' ORDER BY SUBSTRING(MyProjectNo,15,4)
    --查询正确编号
    SELECT MyProjectNo AS '错编号',SUBSTRING(MyProjectNo,15,4) AS '错编号后四位',LEFT(MyProjectNo,14) AS '对编号前14位',
    right('0000'+CAST(row_number() over (order by SUBSTRING(MyProjectNo,15,4))  AS VARCHAR(5)),4) AS '对编号后四位',
    (LEFT(MyProjectNo,14)+right('0000'+CAST(row_number() over (order by SUBSTRING(MyProjectNo,15,4))  AS VARCHAR(5)),4)) AS '对编号'
    FROM dbo.ProjectT 
    WHERE MyProjectNo LIKE '2016%'
    ORDER BY SUBSTRING(MyProjectNo,15,4)
    --更新错误编号为正确(批量脚本)
    SELECT 'UPDATE dbo.ProjectT SET MyProjectNo='''+
    (LEFT(MyProjectNo,14)+right('0000'+CAST(row_number() over (order by SUBSTRING(MyProjectNo,15,4))  AS VARCHAR(5)),4))
    +''' WHERE MyProjectNo='''+MyProjectNo+''''
    FROM dbo.ProjectT 
    WHERE MyProjectNo LIKE '2016%'
    ORDER BY SUBSTRING(MyProjectNo,15,4)

    执行(批量脚本)实现数据重置。

  • 相关阅读:
    zmap zgrab 环境搭建
    RF是如何工作的?
    RF的优缺点
    国内NLP的那些人那些会
    B-、B+、B*树
    关于LDA的gibbs采样,为什么可以获得正确的样本?
    LDA算法里面Dirichlet分布的两个参数alpha和beta怎样确定?
    如何确定LDA的主题个数
    SMO算法精解
    奇异值与主成分分析(PCA)
  • 原文地址:https://www.cnblogs.com/wanghafan/p/5133953.html
Copyright © 2011-2022 走看看