根据sql脚本修改数据库表结构的几种解决方案


最近由于项目需要要做一个小工具。

需求:客户用的老库并存储了一些数据,用了一段时间,我们根据客户提出新功能在老库的基础上对新库进行修改。这些修改有很多细节方面的修改,包含存储过程,增加表,修改表字段类型,添加字段。

然后我们自己更新并测试好软件后,需要改动客户那边的老库,老库的数据是要保存的。

解决方案一:很快我就想到用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命令。当然目前的方案还存在一些问题,这个工具还不够通用,对需要旧表多余的列并没有删除,还有容错性方面考虑得也不够周到。后期还会根据项目需要进一步改进的。



相关阅读:
c#编写的高并发数据库控制访问代码
解析PHP中的file_get_contents获取远程页面乱码的问题
从wamp到xampp的升级之路
如何打开MAC单应用模式将其他的应用窗口最小化
php blowfish加密解密算法
C#中使用XmlDocument类来创建和修改XML格式的数据文件
理解javascript闭包
Mysql DNS反向解析导致连接超时过程分析(skip-name-resolve)
JSP导出Excel文件的方法
Android中ViewPager实现滑动指示条及与Fragment的配合
window.onload与$(document).ready()的区别分析
怎么判断win7中svchost.exe程序是否是病毒?
Android Activity启动模式之singleTop实例详解
优化mysql之key_buffer_size设置
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 大庆西-辽中 随州-全椒 新余北-南平北 石家庄-玉屏 息烽-上饶 西斗铺-艾不盖 灵石-风陵渡 成都东-冷水江东 带岭-开原 公庙子-乌海西 徐州-廊坊北 黎塘-鹿寨 上饶-大余 安庆-马鞍山东 汨罗东-济南西 乐昌-长沙 内江-铜罐驿 昆明-涿州 安陆-广水 蔡家坡-尼勒克 广州-怀化 呼和浩特东-霍州 渑池-滁州北 辛集-井店 三十家-朝阳 吴堡-包头东 玉山-湘潭 八面城-五道沟 旬阳-重庆北 哈密-镇安 辛集-汉中 兖州-包头 查布嘎-海拉尔 祁阳-福田 信阳-新县 聊城-新县 向塘-六枝 东安东-唐河 大辛庄-晋城 攀枝花-迤资 石家庄-白河县 绿潭-双子河 太阳沟-春亭阁 苏家屯-呼兰 锦州南-娄底 张家口南-中卫 子长-呼和浩特 丹凤-进贤 胜芳-孝感北 阿寨-普雄 荆门-泰山 宝鸡-焦作 晋江-巢湖东 蓬安-白河县 新乡-驻马店 宁德-镇江 镇江-惠山 鄯善北-延安 包头-泰和 咸阳-海宁 金华-京山 乌鲁木齐南-石家庄北 六安-杭州 曲阜-北京 玉山-武昌 石家庄北-南岔 南昌-安阳 平峪-三合庄 德阳-向塘 合川-韶关 玉田县-阿城 枣阳-广州北 汝州-向塘 安庆-德州东 白河-泉阳 大东-抚松 无锡东-合肥南 邓家湾-一步滩 山阴-柴沟堡 五女山-雅河 请问望江县哪里能够买到龙灯道具
大家从报名驾校到拿到驾照花了多久
有没有浙江宁波到贵州贵阳或安顺的直达大客
请问从嘉定长途汽车站有到台州玉环的汽车吗?
请问谁知道拱北车站有没有早上9点到揭阳的车
苏州汽车南站到(浙江湖州)的南浔,早上5点到7点有哪几班车
有谁的孩子到荆州教育国际旅行社参加了暑期青岛七日游的,谈
有人知道上海到郑州的客车吗江桥附近的都可以。
长沙和谐号到杭州的票价钱数是多少?
汕头市复印机 打印机加盒 加墨粉
广州东列车火车站到东莞东城怎么走
空之轨迹SC从第五章起的详细攻略
泊头到高唐_泊头到高唐
从许昌鄢陵车站坐客车能到商丘永城吗
听说雅思口语在口语救生圈上面练习会很强大,是不是真的啊!
成都郫县团结镇到都江堰怎么走呢
龙岩到南京高速路如何走
社保怎么从无锡转到镇江
石家庄有顺德甜品店吗
从合肥到温州敖江坐客车汽车多长时间谢谢
从呼伦贝尔火车站到呼伦贝尔学院打车多少钱
从大连坐火车列车到北京站坐那一趟,最好晚上走的,有几趟。不是
k231到惠州列车火车北站还是西站
四川省广安市广安区白市镇
齐齐哈尔一天的旅游线路
K206火车列车座位分布_K206火车列车座位分布
上海出租车外形蓝色的有哪些
寻找有关日本的暴力电影!
请问从扬州自驾去温州路线是什么? 急
上海到大连列车火车票在温州能订吗?

Copyright © 2016 phpStudy |