DBobjectsCompareScript(数据库对象比较).sql
use master
go
IF EXISTS (SELECT * FROM sysobjects WHERE id = OBJECT_ID(N'[func_CompareDBobjectsReColumns_Temp]') AND xtype in (N'FN', N'IF', N'TF'))
DROP FUNCTION [func_CompareDBobjectsReColumns_Temp]
go
create function [func_CompareDBobjectsReColumns_Temp](@objectID int)
returns varchar(1000)
as
begin
declare @str varchar(1000)
set @str = ''
select @str = @str + ', ' + A.name + ' ' + B.name +
case when B.name in('int','datetime') then ''
when B.name in('varchar','nvarchar') then '(' + cast(A.length as varchar) +')'
else ' ' end
--zzl
from syscolumns A, systypes B
where A.xtype = B.xtype and id = @objectID
if(len(@str)) > 0
begin
set @str = ltrim(rtrim(@str))
set @str = right(@str , len(@str) - 1)
end
return ltrim(rtrim(@str))
end
go
declare @sqlStr nvarchar(4000),@dbCurrent nvarchar(20),@dbOK nvarchar(20),@db nvarchar(20)
set @dbOK = 'UBIQTomb_Test0819'
set @db = 'UBIQTomb'
if not exists(select 1 from master..sysdatabases where name= @dbOK)
begin
print '不存在存在数据库名:'+ @dbOK
return;
end
if not exists(select 1 from master..sysdatabases where name= @db)
begin
print '不存在存在数据库名:'+ @db
return;
end
select @dbCurrent = db_name()
--不存在的表
set @sqlStr = 'select * into #tableOK from '+@dbOK+'..sysobjects where xtype=''U'';'
set @sqlStr = @sqlStr+ 'select * into #tableCurrent from '+@db+'..sysobjects where xtype=''U'';'
set @sqlStr = @sqlStr+ 'select +''create table ''+ name +''(''+ '+@dbCurrent+'.dbo.func_CompareDBobjectsReColumns_Temp(id) +'')'' as 表不存在 from #tableOK where name not in(select name from #tableCurrent);'
--不存在的列
set @sqlStr = @sqlStr + ' select A.name as ColumnName,B.name as DataType, A.length as DataLen, C.name as TableName into #cloumnsOK '
+ ' from '+@dbOK+'..syscolumns A, '+@dbOK+'..systypes B, '+@dbOK+'..sysobjects C'
+ ' where A.xtype = B.xtype and A.id = C.id and C.xtype=''U'' and B.name != ''sysname'' and C.name in(select name from #tableOK) and C.name in(select name from #tableCurrent);'
set @sqlStr = @sqlStr + ' select A.name as ColumnName,B.name as DataType, A.length as DataLen, C.name as TableName, A.id as TableID into #cloumnsCurrent '
+ ' from '+@db+'..syscolumns A, '+@db+'..systypes B, '+@db+'..sysobjects C'
+ ' where A.xtype = B.xtype and A.id = C.id and C.xtype=''U'' and B.name != ''sysname'' and C.name in(select name from #tableOK) and C.name in(select name from #tableCurrent);'
set @sqlStr = @sqlStr+ ' select +''alter table ''+ TableName +'' add ''+ ColumnName +'' ''+DataType+'
+'+ case when DataType in(''int'',''datetime'') then '''' when DataType in(''varchar'',''nvarchar'',''char'',''nchar'') then ''('' + cast(DataLen as varchar) +'')'' else '' '' end as 不存在的列'
+' from #cloumnsOK where ColumnName not in(select ColumnName from #cloumnsCurrent where #cloumnsCurrent.TableName = #cloumnsOK.TableName);'
--数据类型不正确,或者数据长度不正确
set @sqlStr = @sqlStr+ ' select +''alter table ''+ TableName +'' alter column ''+ ColumnName +'' ''+DataType+'
+'+ case when DataType in(''int'',''datetime'') then '''' when DataType in(''varchar'',''nvarchar'',''char'',''nchar'') then ''('' + cast(DataLen as varchar) +'')'' else '' '' end as 数据类型不正确或者数据长度不正确'
+' from #cloumnsOK where DataType + cast(DataLen as varchar) not in(select DataType + cast(DataLen as varchar) from #cloumnsCurrent where #cloumnsCurrent.TableName = #cloumnsOK.TableName and #cloumnsCurrent.ColumnName = #cloumnsOK.ColumnName)'
+' and TableName + ColumnName in(select TableName + ColumnName from #cloumnsCurrent)'
exec sp_executesql @sqlStr
set @sqlStr = 'select B.name +''|''+ A.name as ''缺少自增长列的表'''
+' from '+@dbOK+'..syscolumns A, '+@dbOK+'..sysobjects B '
+' where A.id = B.id and A.typestat !=0 and A.colstat !=0 and B.xtype = ''U'''
+' and B.name+A.name not in('
+' select B.name + A.name '
+' from '+@db+'..syscolumns A, '+@db+'..sysobjects B '
+' where A.id = B.id and A.typestat !=0 and A.colstat !=0 and B.xtype = ''U'')'
exec sp_executesql @sqlStr
set @sqlStr = 'select B.name+''|''+A.name as ''缺少主键的表'''
+' from '+@dbOK+'..syscolumns A, '+@dbOK+'..sysobjects B '
+' where A.id = B.id and A.id in(select id from '+@dbOK+'..sysconstraints) and A.colstat = 1 '
+' and B.name+A.name not in('
+' select B.name+A.name'
+' from '+@db+'..syscolumns A, '+@db+'..sysobjects B '
+' where A.id = B.id and A.id in(select id from '+@db+'..sysconstraints) and A.colstat = 1 )'
exec sp_executesql @sqlStr
set @sqlStr = 'select name as ''缺少存储过程'' from '+@dbOK+'..sysobjects where xtype = ''P'' '
+' and name not in(select name from '+@db+'..sysobjects where xtype = ''P'')'
exec sp_executesql @sqlStr
set @sqlStr = 'select name as ''缺少触发器'' from '+@dbOK+'..sysobjects where xtype = ''TR'''
+' and name not in(select name from '+@db+'..sysobjects where xtype = ''TR'')'
exec sp_executesql @sqlStr
set @sqlStr = 'select name as ''缺少函数'' from '+@dbOK+'..sysobjects where xtype = ''FN'''
+' and name not in(select name from '+@db+'..sysobjects where xtype = ''FN'')'
exec sp_executesql @sqlStr
set @sqlStr = 'select name as ''缺少视图'' from '+@dbOK+'..sysobjects where xtype = ''V'''
+' and name not in(select name from '+@db+'..sysobjects where xtype = ''V'')'
exec sp_executesql @sqlStr
go
IF EXISTS (SELECT * FROM sysobjects WHERE id = OBJECT_ID(N'[func_CompareDBobjectsReColumns_Temp]') AND xtype in (N'FN', N'IF', N'TF'))
DROP FUNCTION [func_CompareDBobjectsReColumns_Temp]
DBobjectsCompareScript(数据库对象比较).sql的更多相关文章
- 一些求数据库对象的SQL语句
use [mydb] go --存储过程 SELECT * FROM INFORMATION_SCHEMA.ROUTINES WHERE routine_type='PROCEDURE' AND SP ...
- Sql Server系列:数据库对象
数据库对象是数据库的组成部分,数据表.视图.索引.存储过程以及触发器等都是数据库对象. 数据库的主要对象是数据表,数据表是一系列二维数组的集合,用于存储各种信息. 视图表面上看与表几乎一样,具有一组命 ...
- SQL Server修改数据库对象所有者(Owner)浅析
在SQL Server数据库中如何修改数据库对象(表.视图.存储过程..)的所有者(Owner)呢?一般我们可以使用系统提供的系统存储过程sp_changeobjectowner来修改. 我们先看看s ...
- (二)sql入门 管理数据库对象
在数据库里,有各种各样的对象,除了最常见的表之外,还有诸如视图.索引等数据库对象. 这些对象,在数据库里需要有人来管理,那么谁来管理呢?当然是数据库的使用者了.每个使用者相对于数据库里有一片区域,称为 ...
- C#与数据库访问技术总结(六)之Command对象创建SQl语句代码示例
Command对象创建SQl语句代码示例 说明:前面介绍了 Command 对象的方法和一些属性,回顾一下 Command对象主要用来执行SQL语句.利用Command对象,可以查询数据和修改数据. ...
- 查询Sql Server数据库对象结构
查询Sql Server数据库对象结构 查询数据库 查询架构 查询表 查询列 查询存储过程 查询视图 1.查询某一服务器下所有数据库 select t.[name] as 数据库 from sys.d ...
- SQL Server 数据库对象命名参考
一. 引言 编码规范是一个优秀程序员的必备素质,然而,有很多人非常注重程序中变量.方法.类的命名,却忽视了同样重要的数据库对象命名.这篇文章结合许多技术文章和资料,以及我自己的开发经验,对数据库对象的 ...
- SQL Server IF Exists 判断数据库对象是否存在的用法
1 判断数据库是否存在Sql代码 if exists (select * from sys.databases where name = ’数据库名’) drop database [数据库名] ...
- 基于Python的SQL Server数据库对象同步轻量级实现
缘由 日常工作中经常遇到类似的问题:把某个服务器上的某些指定的表同步到另外一台服务器.类似需求用SSIS或者其他ETL工作很容易实现,比如用SSIS的话就可以,但会存在相当一部分反复的手工操作.建源的 ...
- MySQL优化篇(一),我可以和面试官多聊几句吗?——SQL优化流程与优化数据库对象
我可以和面试官多聊几句吗?只是想偷点技能过来.MySQL优化篇(基于MySQL8.0测试验证),上部分:优化SQL语句.数据库对象,MyISAM表锁和InnoDB锁问题. MyISAM表锁和InnoD ...
随机推荐
- Ignite性能测试以及对redis的对比
测试方法 为了对Ignite做一个基本了解,做了一个性能测试,测试方法也比较简单主要是针对client模式,因为这种方法和使用redis的方式特别像.测试方法很简单主要是下面几点: 不作参数优化,默认 ...
- C# 中参数验证方式的演变
一般在写方法的时候,第一步就是进行参数验证,这也体现了编码者的细心和缜密,但是在很多时候这个过程很枯燥和乏味,比如在拿到一个API设计文档的时候,通常会规定类型参数是否允许为空,如果是字符可能有长度限 ...
- (JS+CSS)实现图片放大效果
代码很简单,在这里就不过多阐述,先上示例图: 实现过程: html部分代码很简单 <div id="outer"> <p>点击图片</p> &l ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统 (源码购买说明)
系列目录 升级日志 !!!重大版本更新:于2016-12-20日完成了系统的结构重构并合并简化了T4(这是一次重要的更新,不需要修改现有功能的代码),代码总行数比上个版本又少了1/3.更新了代码生成器 ...
- Win.ini和注册表的读取写入
最近在做打包的工作,应用程序的配置信息可以放在注册表文件中,但是在以前的16位操作系统下,配置信息放在Win.ini文件中.下面介绍一下Win.ini文件的读写方法和注册表的编程. 先介绍下Win.i ...
- 安装eclipse的maven插件
我们团队用maven来管理项目需要的库文件,其实以前都没听过maven,第一次接触这个,师兄要我直接去装下这个,开始以为还挺简单的,没想到中间遇到了一些小麻烦,现在把我成功安装maven的过程分享下, ...
- C#中Length和Count的区别(个人观点)
这篇文章将会很短...短到比你的JJ还短,当然开玩笑了.网上有说过Length和count的区别,都是很含糊的,我没有发现有 文章说得比较透彻的,所以,虽然这篇文章很短,我还是希望能留在首页,听听大家 ...
- 深入Java虚拟机--判断对象存活状态
程序计数器,虚拟机栈和本地方法栈 首先我们先来看下垃圾回收中不会管理到的内存区域,在Java虚拟机的运行时数据区我们可以看到,程序计数器,虚拟机栈,本地方法栈这三个地方是比较特别的.这个三个部分的特点 ...
- 微软发布VSBT,无需安装Visual Studio即可实现项目编译
安装了Visual Studio的那些使用微软平台的开发者通常能够非常容易地操作自己的项目:打开解决方案,修改内容,设置好所有必须的文件以及配置后编译项目.但是在构建服务器或者持续交付系统等没有安装V ...
- BPM助力企业数字化转型
自九十年代末,流程管理开始引入国内,至今已经有20多年的历史了,由最初的部门级应用向企业级应用转变,大家的认知也经历了一系列的发展变化.不同阶段的信息化水平对企业的流程以及BPM平台也提出了不同的需求 ...