热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

推荐阅读
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 推荐一个ASP的内容管理框架(ASP Nuke)的优势和适用场景
    本文推荐了一个ASP的内容管理框架ASP Nuke,并介绍了其主要功能和特点。ASP Nuke支持文章新闻管理、投票、论坛等主要内容,并可以自定义模块。最新版本为0.8,虽然目前仍处于Alpha状态,但作者表示会继续更新完善。文章还分析了使用ASP的原因,包括ASP相对较小、易于部署和较简单等优势,适用于建立门户、网站的组织和小公司等场景。 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • 生成对抗式网络GAN及其衍生CGAN、DCGAN、WGAN、LSGAN、BEGAN介绍
    一、GAN原理介绍学习GAN的第一篇论文当然由是IanGoodfellow于2014年发表的GenerativeAdversarialNetworks(论文下载链接arxiv:[h ... [详细]
  • 本文介绍了在Win10上安装WinPythonHadoop的详细步骤,包括安装Python环境、安装JDK8、安装pyspark、安装Hadoop和Spark、设置环境变量、下载winutils.exe等。同时提醒注意Hadoop版本与pyspark版本的一致性,并建议重启电脑以确保安装成功。 ... [详细]
  • Android Studio Bumblebee | 2021.1.1(大黄蜂版本使用介绍)
    本文介绍了Android Studio Bumblebee | 2021.1.1(大黄蜂版本)的使用方法和相关知识,包括Gradle的介绍、设备管理器的配置、无线调试、新版本问题等内容。同时还提供了更新版本的下载地址和启动页面截图。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
author-avatar
mobiledu2502927877
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有