午夜国产狂喷潮在线观看|国产AⅤ精品一区二区久久|中文字幕AV中文字幕|国产看片高清在线

    根據(jù)sql腳本修改數(shù)據(jù)庫(kù)表結(jié)構(gòu)
    來源:易賢網(wǎng) 閱讀:835 次 日期:2014-12-04 14:43:38
    溫馨提示:易賢網(wǎng)小編為您整理了“根據(jù)sql腳本修改數(shù)據(jù)庫(kù)表結(jié)構(gòu)”,方便廣大網(wǎng)友查閱!

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

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

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

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

    但是這對(duì)客戶來說還是很不方便的,且數(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語句如下:

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

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

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

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

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

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

    sp_renamedb

    更改數(shù)據(jù)庫(kù)的名稱。

    語法

    sp_renamedb [ @dbname = ] ' old_name ' ,

    [ @newname = ] ' new_name '

    參數(shù)

    [ @dbname = ] ' old_name '

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

    [ @newname = ] ' new_name '

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

    返回代碼值

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

    權(quán)限

    只有 sysadmin 和 dbcreator 固定服務(wù)器角色的成員才能執(zhí)行 sp_renamedb.

    示例

    下例將數(shù)據(jù)庫(kù) 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 '

    參考 復(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ù)就可以把舊庫(kù)結(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)的。

    alter table mytable drop index mdl_tag_use_ix;//mdl_tag_use_ix是上表查出的索引名,key_name

    更多信息請(qǐng)查看IT技術(shù)專欄

    更多信息請(qǐng)查看數(shù)據(jù)庫(kù)
    易賢網(wǎng)手機(jī)網(wǎng)站地址:根據(jù)sql腳本修改數(shù)據(jù)庫(kù)表結(jié)構(gòu)
    由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

    2025國(guó)考·省考課程試聽報(bào)名

    • 報(bào)班類型
    • 姓名
    • 手機(jī)號(hào)
    • 驗(yàn)證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
    工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
    云南網(wǎng)警備案專用圖標(biāo)
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報(bào)警專用圖標(biāo)