SQL质量序列更新

时间:2017-01-20 04:34:14

标签: sql sql-server

我正在使用SQL Server 2012,我遇到的问题是客户序列号以前导零开头(例如0000001),这会导致格式化问题,因为他们通过excel将数据导出到第三方接口。我们试图讨论对excel进行更改,但客户不愿意。

我需要的是一种“简单”的方法来更新所有具有序列号链接(目前为362个表)的表上的所有现有序列号,从1开始排序(例如0000001到1000001)。

1 个答案:

答案 0 :(得分:1)

这样的事情应该有效。

class User < ApplicationRecord
  attr_accessor :remember_token, :activation_token, :reset_token, :remember_digest
  before_save { self.email = email.downcase }
  validates :name,  presence: true, length: { maximum: 50 }
  VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-.]+\.[a-z]+\z/i
  validates :email, presence: true, length: { maximum: 255 },
                    format: { with: VALID_EMAIL_REGEX },
                    uniqueness: { case_sensitive: false }
  has_secure_password   
  validates :password, presence: true, length: { minimum: 6 }
class << self
  # Returns the hash digest of the given string.
  def digest(string)
    cost = ActiveModel::SecurePassword.min_cost ? BCrypt::Engine::MIN_COST :
                                                  BCrypt::Engine.cost
    BCrypt::Password.create(string, cost: cost)
  end

  def remember
    remember_token = User.new_token
    update_attribute(:remember_digest, User.digest(remember_token))
  end



  # Returns a random token.
  def new_token
    SecureRandom.urlsafe_base64
  end
end
  # Returns true if the given token matches the digest.
  def authenticated?(remember_token)
    BCrypt::Password.new(remember_digest).is_password?(remember_token)
  end
  # Forgets a user.
  def forget
    update_attribute(:remember_digest, nil)
  end

  def activate
    update_attribute(:activated,    true)
    update_attribute(:activated_at, Time.zone.now)
  end

end

注意: 如果列用于此类约束,则可能需要禁用外键和其他键