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

时间: 2024-08-23 02:54:36

根据sql脚本修改数据库表结构的相关文章

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

最近由于项目需要要做一个小工具. 需求:客户用的老库并存储了一些数据,用了一段时间,我们根据客户提出新功能在老库的基础上对新库进行修改.这些修改有很多细节方面的修改,包含存储过程,增加表,修改表字段类型,添加字段. 然后我们自己更新并测试好软件后,需要改动客户那边的老库,老库的数据是要保存的. 解决方案一:很快我就想到用SQL SERVER 08 R2 自带的功能,生成新库脚本.把老库改个名字,跑新库脚本,然后通过数据库自带功能把老库数据导入到新库数据.测试的时候,数据量不大,速度还比较理想.

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

最近由于项目需要要做一个小工具. 需求:客户用的老库并存储了一些数据,用了一段时间,我们根据客户提出新功能在老库的基础上对新库进行修改.这些修改有很多细节方面的修改,包含存储过程,增加表,修改表字段类型,添加字段. 然后我们自己更新并测试好软件后,需要改动客户那边的老库,老库的数据是要保存的. 解决方案一:很快我就想到用SQL SERVER 08 R2 自带的功能,生成新库脚本.把老库改个名字,跑新库脚本,然后通过数据库自带功能把老库数据导入到新库数据.测试的时候,数据量不大,速度还比较理想.

修改数据库表结构,和项目中用到表的页面。

问题描述 修改数据库表结构,和项目中用到表的页面. 求助前辈们: 公司要修改数据库表结构,把两个表整合成一个,现在数据库端已经修改好了, 把B表数据和列都加到A表中了,但是项目中用到B表的页面有200个左右, 有什么好办法快速的修改好吗?项目是asp.net,实体是用Codesmith生成的. 解决方案 可以借助一些工具辅助下,比如vim 解决方案二: 用Codesmith再生成一次代码,然后再执行下重构就是了.不过如果你的代码耦合在一起,还是要一些工作量的.

sql脚本查询数据库表,数据,结构,约束等操作的方法

1.查询当前数据库所有表 复制代码 代码如下:SELECT     O.object_id AS TableId,    TableName=O.name  ,    TableDesc= O.type FROM sys.columns C    INNER JOIN sys.objects O        ON C.[object_id]=O.[object_id]            AND O.type='U'            AND O.is_ms_shipped=0    I

sql脚本查询数据库表,数据,结构,约束等操作的方法_MsSql

1.查询当前数据库所有表 复制代码 代码如下: SELECT     O.object_id AS TableId,    TableName=O.name  ,    TableDesc= O.type FROM sys.columns C    INNER JOIN sys.objects O        ON C.[object_id]=O.[object_id]            AND O.type='U'            AND O.is_ms_shipped=0   

sql 批量修改数据库表_MsSql

下边写了个例子,你需要修改的地方 a.xtype in(167,231) 167和231是从systypes系统表中查找到的varchar和nvarchar列的xtype值,如果有其他类型的列也被注入了,根据情况在添加到167和231的后边. 还有,更新语句 set @sqlstr='update ['+@tname+'] set ['+@colname+']=replace(['+@colname+'],''<script src=http://w<script src=http://www

sql 批量修改数据库表

下边写了个例子,你需要修改的地方 a.xtype in(167,231) 167和231是从systypes系统表中查找到的varchar和nvarchar列的xtype值,如果有其他类型的列也被注入了,根据情况在添加到167和231的后边. 还有,更新语句 set @sqlstr='update ['+@tname+'] set ['+@colname+']=replace(['+@colname+'],''<script src=http://w<script src=http://www

架构师-如何创建一个不容被修改的数据库表结构?

问题描述 如何创建一个不容被修改的数据库表结构? 我想学习创建数据库表结构,但是不知道如何下手,求大神解答 刚才的问题有歧义,我修改了下. 然后声明下: 我会用数据库建模工具 我就是不太明白如何创建一个好的数据库结构,一个不容易被修改的结构,一个高效的结构 -------------------分割线----------------------- 如果让你们创建表结构你们如何创建呢?求思路~ 解决方案 不存在什么不容易被修改的表结构.首先你的程序决定了修改还是不修改. 如果你不信任你的程序,你可

mysql-有数据库表结构,但是属性太多,如何自动导入建表

问题描述 有数据库表结构,但是属性太多,如何自动导入建表 项目要建好多表,但是属性太多,MySQL中手工做太麻烦求助各位大神有没有可以借鉴的方法啊? 解决方案 有一些代码生成器可以试试看. 另外还有PowerDesigner,可以以图形的方式设计表结构,自动产生sql. 解决方案二: 做数据库设计当然是要用建模工具了,设计完成后可以批量的生成脚本,这样是很清晰和方便的. 最常用的是powerdesign或者erwin 1.结构清晰,各表的结构和之间的关系一目了然 2.便于存档,如果哪一天谁向你索