您好,登錄后才能下訂單哦!
根據(jù)sql腳本修改數(shù)據(jù)庫表結(jié)構(gòu)的解決方案有哪幾種,針對(duì)這個(gè)問題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡(jiǎn)單易行的方法。
最近由于項(xiàng)目需要要做一個(gè)小工具。 需求:客戶用的老庫并存儲(chǔ)了一些數(shù)據(jù),用了一段時(shí)間,我們根據(jù)客戶提出新功能在老庫的基礎(chǔ)上對(duì)新庫進(jìn)行修改。這些修改有很多細(xì)節(jié)方面的修改,包含存儲(chǔ)過程,增加表,修改表字段類型,添加字段。 然后我們自己更新并測(cè)試好軟件后,需要改動(dòng)客戶那邊的老庫,老庫的數(shù)據(jù)是要保存的。 解決方案一:很快我就想到用SQL SERVER 08 R2 自帶的功能,生成新庫腳本。把老庫改個(gè)名字,跑新庫腳本,然后通過數(shù)據(jù)庫自帶功能把老庫數(shù)據(jù)導(dǎo)入到新庫數(shù)據(jù)。測(cè)試的時(shí)候,數(shù)據(jù)量不大,速度還比較理想。 但是這對(duì)客戶來說還是很不方便的,且數(shù)據(jù)量大些還是比較費(fèi)時(shí)的。于是,boss就讓我做個(gè)小工具吧。 難道我要用程序?qū)崿F(xiàn)以上操作,oh my god ! 于是我想啊想。。。。 解決方案二:我就再細(xì)一些,直接操作數(shù)據(jù)庫的表吧,對(duì)于數(shù)據(jù)庫中存在的表,我給它重新命名,跑個(gè)新腳本建表,然后把老表中數(shù)據(jù)插進(jìn)去。 相關(guān)SQL語句如下: 修改表名:EXEC sp_rename 'oldName' , 'newName' 插入數(shù)據(jù):insert into newTable(column1,column2,.....) select column1,column2,..... from oldTable 更多相關(guān)操作: 參考數(shù)據(jù)庫、表、列的重命名 列出參考內(nèi)容來方便查看 一、更改數(shù)據(jù)庫名復(fù)制代碼 代碼如下: sp_renamedb 更改數(shù)據(jù)庫的名稱。 語法 sp_renamedb [ @dbname = ] ' old_name ' , [ @newname = ] ' new_name ' 參數(shù) [ @dbname = ] ' old_name ' 是數(shù)據(jù)庫的當(dāng)前名稱。old_name 為 sysname 類型,無默認(rèn)值。 [ @newname = ] ' new_name ' 是數(shù)據(jù)庫的新名稱。new_name 必須遵循標(biāo)識(shí)符規(guī)則。new_name 為 sysname 類型,無默認(rèn)值。 返回代碼值 0 (成功)或非零數(shù)字(失?。?權(quán)限 只有 sysadmin 和 dbcreator 固定服務(wù)器角色的成員才能執(zhí)行 sp_renamedb。 示例 下例將數(shù)據(jù)庫 accounting 改名為 financial。 EXEC sp_renamedb ' accounting ' , ' financial '
二、更改表名或列名復(fù)制代碼 代碼如下: 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 '
參考 復(fù)制表結(jié)構(gòu)和表數(shù)據(jù)的SQL語句 列出參考內(nèi)容來方便查看 1.復(fù)制表結(jié)構(gòu)及數(shù)據(jù)到新表 CREATE TABLE 新表 SELECT * FROM 舊表 2.只復(fù)制表結(jié)構(gòu)到新表 CREATE TABLE 新表 SELECT * FROM 舊表 WHERE 1=2 即:讓W(xué)HERE條件不成立. 方法二:(由tianshibao提供) CREATE TABLE 新表 LIKE 舊表 3.復(fù)制舊表的數(shù)據(jù)到新表(假設(shè)兩個(gè)表結(jié)構(gòu)一樣) INSERT INTO 新表 SELECT * FROM 舊表 4.復(fù)制舊表的數(shù)據(jù)到新表(假設(shè)兩個(gè)表結(jié)構(gòu)不一樣) INSERT INTO 新表(字段1,字段2,.......) SELECT 字段1,字段2,...... FROM 舊表 想到這,發(fā)現(xiàn)好像還少了點(diǎn)什么,呃,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_] 這里再補(bǔ)充一些東西,關(guān)于約束前綴,參考SQL約束前綴 方便查看,再列出來 --主鍵 constraint PK_字段 primary key(字段), --唯一約束 constraint UK_字段 unique key(字段), --默認(rèn)約束 constrint DF_字段 default('默認(rèn)值') for 字段, --檢查約束 constraint CK_字段 check(約束。如:len(字段)>1), --主外鍵關(guān)系 constraint FK_主表_從表 foreign(外鍵字段) references 主表(主表主鍵字段) 然后再?gòu)哪_本中讀取相應(yīng)腳本文件并執(zhí)行(加句廢話:要執(zhí)行多行腳本文件,CommandText里加'\n'就好了)。 解決方案三:思來想去,為什么非要導(dǎo)入數(shù)據(jù),直接改表結(jié)構(gòu)就好了呀。于是讀取表中字段 select column_name,data_type from information_schema.columns where table_name = 'tableName' 對(duì)于舊表中存在的字段 ALTER TABLE [tableName] ALTER COLUMN [columnName] [int] NOT NULL 對(duì)于舊表中不存在的字段 ALTER TABLE [tableName] ADD COLUMN [columnName] [int] NOT NULL 這樣一來就不用導(dǎo)入數(shù)據(jù)就可以把舊庫結(jié)構(gòu)更新,其中除了運(yùn)用一些ADO.NET方面的知識(shí),還用到了正則表達(dá)式之類的來匹配腳本中相應(yīng)的SQL命令。當(dāng)然目前的方案還存在一些問題,這個(gè)工具還不夠通用,對(duì)需要舊表多余的列并沒有刪除,還有容錯(cuò)性方面考慮得也不夠周到。后期還會(huì)根據(jù)項(xiàng)目需要進(jìn)一步改進(jìn)的。
關(guān)于根據(jù)sql腳本修改數(shù)據(jù)庫表結(jié)構(gòu)的解決方案有哪幾種問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。