主頁(yè) > 知識(shí)庫(kù) > 根據(jù)sql腳本修改數(shù)據(jù)庫(kù)表結(jié)構(gòu)的幾種解決方案

根據(jù)sql腳本修改數(shù)據(jù)庫(kù)表結(jié)構(gòu)的幾種解決方案

熱門(mén)標(biāo)簽:安陽(yáng)天音防封電銷(xiāo)卡 外呼系統(tǒng)的話(huà)術(shù) 陽(yáng)光創(chuàng)信ai外呼獲客系統(tǒng)助力 貴州外呼回?fù)芟到y(tǒng)是什么 衛(wèi)星地圖標(biāo)注距離 智能外呼系統(tǒng)需要多少錢(qián) 云南全自動(dòng)外呼系統(tǒng)公司 競(jìng)圣地圖標(biāo)注服務(wù) 智能語(yǔ)音車(chē)載電話(huà)機(jī)器人

最近由于項(xiàng)目需要要做一個(gè)小工具。

需求:客戶(hù)用的老庫(kù)并存儲(chǔ)了一些數(shù)據(jù),用了一段時(shí)間,我們根據(jù)客戶(hù)提出新功能在老庫(kù)的基礎(chǔ)上對(duì)新庫(kù)進(jìn)行修改。這些修改有很多細(xì)節(jié)方面的修改,包含存儲(chǔ)過(guò)程,增加表,修改表字段類(lèi)型,添加字段。

然后我們自己更新并測(cè)試好軟件后,需要改動(dòng)客戶(hù)那邊的老庫(kù),老庫(kù)的數(shù)據(jù)是要保存的。

解決方案一:很快我就想到用SQL SERVER 08 R2 自帶的功能,生成新庫(kù)腳本。把老庫(kù)改個(gè)名字,跑新庫(kù)腳本,然后通過(guò)數(shù)據(jù)庫(kù)自帶功能把老庫(kù)數(shù)據(jù)導(dǎo)入到新庫(kù)數(shù)據(jù)。測(cè)試的時(shí)候,數(shù)據(jù)量不大,速度還比較理想。

但是這對(duì)客戶(hù)來(lái)說(shuō)還是很不方便的,且數(shù)據(jù)量大些還是比較費(fèi)時(shí)的。于是,boss就讓我做個(gè)小工具吧。

難道我要用程序?qū)崿F(xiàn)以上操作,oh my god !

于是我想啊想。。。。

解決方案二:我就再細(xì)一些,直接操作數(shù)據(jù)庫(kù)的表吧,對(duì)于數(shù)據(jù)庫(kù)中存在的表,我給它重新命名,跑個(gè)新腳本建表,然后把老表中數(shù)據(jù)插進(jìn)去。

相關(guān)SQL語(yǔ)句如下:

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

插入數(shù)據(jù):insert into newTable(column1,column2,.....) select column1,column2,..... from oldTable

更多相關(guān)操作:

參考數(shù)據(jù)庫(kù)、表、列的重命名

列出參考內(nèi)容來(lái)方便查看

一、更改數(shù)據(jù)庫(kù)名

復(fù)制代碼 代碼如下:

sp_renamedb
更改數(shù)據(jù)庫(kù)的名稱(chēng)。

語(yǔ)法
sp_renamedb [ @dbname = ] ' old_name ' ,
[ @newname = ] ' new_name '

參數(shù)
[ @dbname = ] ' old_name '

是數(shù)據(jù)庫(kù)的當(dāng)前名稱(chēng)。old_name 為 sysname 類(lèi)型,無(wú)默認(rèn)值。

[ @newname = ] ' new_name '

是數(shù)據(jù)庫(kù)的新名稱(chēng)。new_name 必須遵循標(biāo)識(shí)符規(guī)則。new_name 為 sysname 類(lèi)型,無(wú)默認(rèn)值。

返回代碼值
0 (成功)或非零數(shù)字(失?。?

權(quán)限
只有 sysadmin 和 dbcreator 固定服務(wù)器角色的成員才能執(zhí)行 sp_renamedb。

示例
下例將數(shù)據(jù)庫(kù) 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語(yǔ)句

列出參考內(nèi)容來(lá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,好吧,那我也先刪除再添加
先查出來(lái)
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約束前綴
方便查看,再列出來(lái)
--主鍵
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í)行(加句廢話(huà):要執(zhí)行多行腳本文件,CommandText里加'\n'就好了)。

解決方案三:思來(lái)想去,為什么非要導(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

這樣一來(lái)就不用導(dǎo)入數(shù)據(jù)就可以把舊庫(kù)結(jié)構(gòu)更新,其中除了運(yùn)用一些ADO.NET方面的知識(shí),還用到了正則表達(dá)式之類(lèi)的來(lái)匹配腳本中相應(yīng)的SQL命令。當(dāng)然目前的方案還存在一些問(wèn)題,這個(gè)工具還不夠通用,對(duì)需要舊表多余的列并沒(méi)有刪除,還有容錯(cuò)性方面考慮得也不夠周到。后期還會(huì)根據(jù)項(xiàng)目需要進(jìn)一步改進(jìn)的。

標(biāo)簽:周口 營(yíng)口 欽州 寧夏 湘潭 鄂爾多斯 預(yù)約服務(wù) 河源

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《根據(jù)sql腳本修改數(shù)據(jù)庫(kù)表結(jié)構(gòu)的幾種解決方案》,本文關(guān)鍵詞  根據(jù),sql,腳本,修改,數(shù)據(jù)庫(kù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《根據(jù)sql腳本修改數(shù)據(jù)庫(kù)表結(jié)構(gòu)的幾種解決方案》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于根據(jù)sql腳本修改數(shù)據(jù)庫(kù)表結(jié)構(gòu)的幾種解決方案的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章