最近由于項目需要要做一個小工具。
需求:客戶用的老庫并存儲了一些數據,用了一段時間,我們根據客戶提出新功能在老庫的基礎上對新庫進行修改。這些修改有很多細節方面的修改,包含存儲過程,增加表,修改表字段類型,添加字段。
然后我們自己更新并測試好軟件后,需要改動客戶那邊的老庫,老庫的數據是要保存的。
解決方案一:很快我就想到用sql server 08 r2 自帶的功能,生成新庫腳本。把老庫改個名字,跑新庫腳本,然后通過數據庫自帶功能把老庫數據導入到新庫數據。測試的時候,數據量不大,速度還比較理想。
但是這對客戶來說還是很不方便的,且數據量大些還是比較費時的。于是,boss就讓我做個小工具吧。
難道我要用程序實現以上操作,oh my god !
于是我想啊想…
解決方案二:我就再細一些,直接操作數據庫的表吧,對于數據庫中存在的表,我給它重新命名,跑個新腳本建表,然后把老表中數據插進去。
相關sql語句如下:
修改表名:exec sp_rename 'oldname' , 'newname'
插入數據:insert into newtable(column1,column2,……) select column1,column2,…… from oldtable
更多信息請查看IT技術專欄