首页 > 网站 > 建站经验 > 正文

根据sql脚本修改数据库表结,构

2019-11-02 14:47:47
字体:
来源:转载
供稿:网友

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

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

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

  解决方案一:很快我就想到用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,好吧,那我也先删除再添加

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表