最近在工作中遇到一個問題,面對一個有上百萬數據的表如何給他添加主鍵,有這種問題的往往是在業務初期建表是忘記了設置主鍵,等到系統在正式庫上跑了一段時間之後,表中添加了大量的數據,這個時候想要給表添加主鍵時就會遇到這個問題, 面對這個問題我們可以藉助oracle中的序列,代碼如下: update tab ...
最近在工作中遇到一個問題,面對一個有上百萬數據的表如何給他添加主鍵,有這種問題的往往是在業務初期建表是忘記了設置主鍵,等到系統在正式庫上跑了一段時間之後,表中添加了大量的數據,這個時候想要給表添加主鍵時就會遇到這個問題,
面對這個問題我們可以藉助oracle中的序列,代碼如下:
update tablename d
set d.f_id = to_char(sysdate,'yyyymmdd') || lpad(sequence_name.Nextval,8,'0');
'8'和'0'代表我新建的序列是8位,如果不夠8位用'0'填充