好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 根據sql腳本修改數據庫表結構的幾種解決方案

根據sql腳本修改數據庫表結構的幾種解決方案

熱門標簽:安陽天音防封電銷卡 外呼系統的話術 陽光創信ai外呼獲客系統助力 貴州外呼回撥系統是什么 衛星地圖標注距離 智能外呼系統需要多少錢 云南全自動外呼系統公司 競圣地圖標注服務 智能語音車載電話機器人

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

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

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

解決方案一:很快我就想到用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,好吧,那我也先刪除再添加
先查出來
select name from sys.procedures
select constraint_name, table_name from information_schema.table_constraints
再刪除
drop procedure [dbo].[procedure_name]
alter table tableName drop CONSTRAINT [PK_ |FK_ |UK_ |DF_ |CK_]
這里再補充一些東西,關于約束前綴,參考SQL約束前綴
方便查看,再列出來
--主鍵
constraint PK_字段 primary key(字段),

--唯一約束
constraint UK_字段 unique key(字段),

--默認約束
constrint DF_字段 default('默認值') for 字段,

--檢查約束
constraint CK_字段 check(約束。如:len(字段)>1),

--主外鍵關系
constraint FK_主表_從表 foreign(外鍵字段) references 主表(主表主鍵字段)

然后再從腳本中讀取相應腳本文件并執行(加句廢話:要執行多行腳本文件,CommandText里加'\n'就好了)。

解決方案三:思來想去,為什么非要導入數據,直接改表結構就好了呀。于是讀取表中字段

select column_name,data_type from information_schema.columns where table_name = 'tableName'
對于舊表中存在的字段
ALTER TABLE [tableName] ALTER COLUMN [columnName] [int] NOT NULL
對于舊表中不存在的字段
ALTER TABLE [tableName] ADD COLUMN [columnName] [int] NOT NULL

這樣一來就不用導入數據就可以把舊庫結構更新,其中除了運用一些ADO.NET方面的知識,還用到了正則表達式之類的來匹配腳本中相應的SQL命令。當然目前的方案還存在一些問題,這個工具還不夠通用,對需要舊表多余的列并沒有刪除,還有容錯性方面考慮得也不夠周到。后期還會根據項目需要進一步改進的。

標簽:周口 營口 欽州 寧夏 湘潭 鄂爾多斯 預約服務 河源

巨人網絡通訊聲明:本文標題《根據sql腳本修改數據庫表結構的幾種解決方案》,本文關鍵詞  根據,sql,腳本,修改,數據庫,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《根據sql腳本修改數據庫表結構的幾種解決方案》相關的同類信息!
  • 本頁收集關于根據sql腳本修改數據庫表結構的幾種解決方案的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 老牛影视AV一区二区在线观看| japan色系videos强行| 免费播放片 a大片 播放器| 国产亚洲欧美另类久久久| 胸罩女露吃胸乳头上衣蕾丝薄| 艹女| MJ国产精品视频一区二区| 羞羞动漫动漫被黄漫免费| 嫩模李丽莎喷水福利视频| 欧美深度肠交| 校花被农民工调教羞辱| 中文字幕乱近親相姦886008 | 韩国美女激情vip秀福利| 边吃早餐边肉她h| 凹凸国产AV熟女白浆精品视| 两根一进一出啊灌满了视频| 久久亚洲一区二区| 啦啦啦的视频在线观看3| 9lPORNY九色视频l偷拍| 亚洲精品少妇久久久久久海角社区| 又粗又大又长又硬好舒服爽| 欧美一级黄色片子| 女的被到爽羞羞jk漫画视频| 成人国产在线视频| 美国色情三级欧美三级| 中文字幕av人妻互换久久黄桃| 男生舔女生逼| 久久99精品久久久久久久不卡 | 《守望人妻》完整无删减| 涩涩视频观看| 韩国伦理电影密爱| 小兰被?到喷水18禁视频| 激情综合网五月婷婷| 美女主播露胸 揉胸| 美女裸体?开腿玩小玩具| 午夜激情免费视频| 91国内精品人妻无码久久久影院| 日韩精品婷婷五月伊人九色| 看美女的隐私免费视频| 99久久中文字幕伊人| 91女神娇喘疯狂3p之夜|