亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

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

2024-08-31 01:02:08
字體:
來源:轉載
供稿:網友

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

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

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

解決方案一:很快我就想到用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命令。當然目前的方案還存在一些問題,這個工具還不夠通用,對需要舊表多余的列并沒有刪除,還有容錯性方面考慮得也不夠周到。后期還會根據項目需要進一步改進的。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文在线资源观看视频网站免费不卡| 日韩专区在线观看| 午夜精品福利在线观看| 国产成人精品在线观看| 国产91精品青草社区| 这里只有视频精品| 最近2019中文字幕一页二页| 精品国产乱码久久久久久婷婷| 精品香蕉在线观看视频一| 亚洲欧美国产视频| 日韩成人小视频| 亚洲激情久久久| 日韩电影在线观看中文字幕| 日韩免费看的电影电视剧大全| 亚洲国产精品一区二区三区| 欧美高清性猛交| 国产精品国产福利国产秒拍| 国产精品中文在线| 欧美激情精品久久久久久久变态| 中文字幕亚洲一区| 亚洲xxxx在线| 欧美成人午夜激情视频| 国产在线精品播放| 尤物九九久久国产精品的特点| 亚洲第一区在线观看| 久久精品国产清自在天天线| 国产亚洲免费的视频看| 国产精品一区二区电影| 国产成人涩涩涩视频在线观看| 日韩电影免费在线观看中文字幕| 国产日韩欧美日韩| 久久免费在线观看| 欧美午夜片在线免费观看| 久久91精品国产91久久跳| 国产a∨精品一区二区三区不卡| 日韩电影第一页| 欧美日韩在线视频观看| 欧美激情久久久久久| 久久艹在线视频| 亚洲欧美在线看| 成人免费淫片视频软件| 18一19gay欧美视频网站| 91精品久久久久久久久久另类| 草民午夜欧美限制a级福利片| 日韩精品免费电影| 久久视频在线直播| 成人午夜激情免费视频| 久99九色视频在线观看| 奇米四色中文综合久久| 69久久夜色精品国产69乱青草| 日韩av免费在线播放| 欧美精品在线免费| 久久精品国产亚洲精品2020| 亚洲精选一区二区| 青青a在线精品免费观看| 精品国产老师黑色丝袜高跟鞋| 中国日韩欧美久久久久久久久| 日本精品视频在线播放| 98午夜经典影视| 亚洲bt欧美bt日本bt| 亚洲精品日韩av| 欧美激情中文网| 亚洲一区二区三区成人在线视频精品| 97视频色精品| 日韩高清人体午夜| 久久久视频精品| 亚洲va欧美va在线观看| 亚洲在线一区二区| 一区二区三区精品99久久| 亚洲影视中文字幕| 日韩av片永久免费网站| 九九热精品视频在线播放| 成人美女免费网站视频| 欧美精品制服第一页| 91精品国产综合久久久久久久久| 色婷婷综合久久久久| 国产成人精品视频在线| 国产视频久久网| 黑人欧美xxxx| 欧洲成人在线视频| 日韩电影中文字幕av| 亚洲精品久久久久中文字幕欢迎你| 欧美视频专区一二在线观看| 成人在线视频网站| 亚洲国产成人爱av在线播放| 欧美日韩精品在线视频| 狠狠色噜噜狠狠狠狠97| 国产成人福利夜色影视| 国产日韩精品在线观看| 日韩精品免费在线视频观看| 成人免费黄色网| 日产日韩在线亚洲欧美| 亚洲欧美国产日韩中文字幕| 日本久久久久亚洲中字幕| 97精品国产aⅴ7777| 精品国产91久久久久久老师| 在线日韩精品视频| 久久视频在线直播| 国产亚洲精品久久久久动| 欧美激情第1页| 国产人妖伪娘一区91| 国产午夜精品视频| 日韩成人免费视频| 亚洲国产欧美在线成人app| 欧美性xxxxxxxxx| 久久精品久久久久电影| 成人免费大片黄在线播放| 亚洲人成网在线播放| 日韩女优在线播放| 亚洲电影免费观看高清完整版在线观看| 成人精品视频99在线观看免费| 欧美日韩精品在线| 欧美猛少妇色xxxxx| 国产午夜精品免费一区二区三区| 欧美丰满片xxx777| 中文字幕日韩av综合精品| 久久久久久久久爱| 亚洲电影在线观看| 亚洲欧美在线x视频| 中日韩美女免费视频网站在线观看| 久久国产精品视频| 亚洲国产日韩欧美在线动漫| 成人免费xxxxx在线观看| 91精品久久久久久久久不口人| 日韩一区二区三区在线播放| 日韩av在线免费| 亚洲精品在线观看www| 美女av一区二区三区| 久久偷看各类女兵18女厕嘘嘘| 国产精品88a∨| 亚洲国产欧美精品| 欧美激情奇米色| 亚洲韩国青草视频| 91亚洲精华国产精华| 亚洲3p在线观看| 国产在线久久久| 亚洲剧情一区二区| 97人人模人人爽人人喊中文字| 国产精自产拍久久久久久蜜| 精品无人区太爽高潮在线播放| 日韩美女在线观看| 欧美在线视频导航| 国产欧美日韩精品在线观看| 亚洲视频第一页| 色综合久久久久久中文网| 国产精品免费久久久久久| 欧美日韩国产第一页| 久久91精品国产| 91精品在线国产| 日本精品中文字幕| 深夜福利国产精品| 亚洲欧美国产制服动漫| 国产精品入口福利| 国产色综合天天综合网| 91成人天堂久久成人| 亚洲级视频在线观看免费1级| 中文欧美在线视频| 日韩毛片中文字幕| 亚洲大胆美女视频| 国产婷婷色综合av蜜臀av| 国产情人节一区| 91亚洲精华国产精华| 精品久久久久久中文字幕大豆网| 亚洲va久久久噜噜噜|