根據sql腳本修改數據庫表結,構

發布時間:2017-09-10 06:06 來源:互聯網 當前欄目:web技術類

   最近由于項目需要要做一個小工具。

  需求:客戶用的老庫并存儲了一些數據,用了一段時間,我們根據客戶提出新功能在老庫的基礎上對新庫進行修改。這些修改有很多細節方面的修改,包含存儲過程,增加表,修改表字段類型,添加字段。

  然后我們自己更新并測試好軟件后,需要改動客戶那邊的老庫,老庫的數據是要保存的。

  解決方案一:很快我就想到用SQL SERVER 08 R2 自帶的功能,生成新庫腳本。把老庫改個名字,跑新庫腳本,然后通過數據庫自帶功能把老庫數據導入到新庫數據。測試的時候,數據量不大,速度還比較理想。

  但是這對客戶來說還是很不方便的,且數據量大些還是比較費時的。于是,boss就讓我做個小工具吧。

  難道我要用程序實現以上操作,oh my god !

  于是我想啊想…

  解決方案二:我就再細一些,直接操作數據庫的表吧,對于數據庫中存在的表,我給它重新命名,跑個新腳本建表,然后把老表中數據插進去。

  相關SQL語句如下:

  修改表名:EXEC sp_rename 'oldName' , 'newName'

  插入數據:insert into newTable(column1,column2,……) select column1,column2,…… from oldTable

  更多相關操作:

  參考數據庫、表、列的重命名

  列出參考內容來方便查看

  一、更改數據庫名

  sp_renamedb

  更改數據庫的名稱。

  語法

  sp_renamedb [ @dbname = ] ' old_name ' ,

  [ @newname = ] ' new_name '

  參數

  [ @dbname = ] ' old_name '

  是數據庫的當前名稱。old_name 為 sysname 類型,無默認值。

  [ @newname = ] ' new_name '

  是數據庫的新名稱。new_name 必須遵循標識符規則。new_name 為 sysname 類型,無默認值。

  返回代碼值

  0 (成功)或非零數字(失敗)

  權限

  只有 sysadmin 和 dbcreator 固定服務器角色的成員才能執行 sp_renamedb.

  示例

  下例將數據庫 accounting 改名為 financial.

  EXEC sp_renamedb ' accounting ' , ' financial '

  二、更改表名或列名

  sp_rename [ @objname = ] ' object_name ' ,

  [ @newname = ] ' new_name '

  [ , [ @objtype = ] ' object_type ' ]

  /////////////////////////////////////////////

  A. 重命名表

  下例將表 customers 重命名為 custs.

  EXEC sp_rename ' customers ' , ' custs '

  B. 重命名列

  下例將表 customers 中的列 contact title 重命名為 title.

  EXEC sp_rename ' customers.[contact title] ' , ' title ' , ' COLUMN '

  參考 復制表結構和表數據的SQL語句

  列出參考內容來方便查看

  1.復制表結構及數據到新表

  CREATE TABLE 新表 SELECT * FROM 舊表

  2.只復制表結構到新表

  CREATE TABLE 新表 SELECT * FROM 舊表 WHERE 1=2

  即:讓WHERE條件不成立。

  方法二:(由tianshibao提供)

  CREATE TABLE 新表 LIKE 舊表

  3.復制舊表的數據到新表(假設兩個表結構一樣)

  INSERT INTO 新表 SELECT * FROM 舊表

  4.復制舊表的數據到新表(假設兩個表結構不一樣)

  INSERT INTO 新表(字段1,字段2,……) SELECT 字段1,字段2,…… FROM 舊表

  想到這,發現好像還少了點什么,呃,procedure和constraint,好吧,那我也先刪除再添加

  • 1、
  • 2、
  • 3、
  • 4、
  • 5、
  • 6、
  • 7、
  • 8、
  • 9、
  • 10、
  • 11、
  • 12、
  • 13、
  • 14、
  • 15、
  • 16、
  • 17、
  • 18、
  • 19、
  • 20、
  • 21、
  • 22、
  • 23、
  • 24、
  • 25、
  • 1、
  • 2、
  • 3、
  • 4、
  • 5、
  • 6、
  • 7、
  • 8、
  • 9、
  • 10、
  • 11、
  • 12、
  • 13、
  • 14、
  • 15、
  • 16、
  • 17、
  • 18、
  • 19、
  • 20、
  • 21、
  • 22、
  • 23、
  • 24、
  • 25、