做一个数据库比对小工具,把SQL做一个笔记

SELECT object_id AS ID --表ID
,'表' sType
,Name --表名
FROM sys.tables
ORDER BY Name
--字段
SELECT A.Name --字段名
,'字段' sType
,B.name AS typeName --字段类型
,A.max_length AS typeLength --长度(nvarchar要除以2 -1等于max)
,C.text AS defaultValue --默认值
,A.object_id AS PID --表名
,A.is_nullable AS [isNull] --是否为空
,A.is_identity AS isIdentity --是否值增长
, CASE WHEN IC.object_id IS NULL THEN 0 ELSE 1 END AS isPK --是否主键(自带聚集索引)
, CASE WHEN IC.object_id IS NULL THEN 0 ELSE 1 END AS isUnique --是否唯一
FROM sys.columns A
INNER JOIN sys.types B ON A.user_type_id=B.user_type_id
INNER JOIN sys.tables D ON D.object_id=A.object_id
LEFT JOIN sys.syscomments C ON A.default_object_id=C.id
LEFT JOIN sys.objects OB ON OB.parent_object_id=A.object_id AND OB.type='PK'
LEFT JOIN sys.indexes S ON S.name=OB.name
LEFT JOIN sys.index_columns IC ON IC.object_id = A.object_id AND ic.index_id=s.index_id AND ic.column_id=A.column_id
ORDER BY A.object_id,A.column_id

--非主键关联的索引
SELECT A.Name --索引名
,'索引' sType
,D.NAME AS colName --关联字段名
,A.object_id AS PID --表名
,A.type_desc AS typeDesc--索引类型
,A.is_unique AS isUnique --是否唯一
FROM SYS.INDEXES A
JOIN SYS.INDEX_COLUMNS B ON (A.object_id = B.object_id AND A.index_id = B.index_id)
JOIN SYS.TABLES C ON (A.object_id = C.object_id)
JOIN SYS.COLUMNS D ON (A.object_id = D.object_id AND B.column_id = D.column_id)
WHERE A.is_primary_key=0
ORDER BY A.object_id,B.index_column_id
--触发器
SELECT A.parent_id AS PID --表ID
,'触发器' sType
,A.Name --触发器名称
,B.Text --触发器内容
FROM sys.triggers A
INNER JOIN sys.syscomments B ON A.object_id=B.id
ORDER BY A.name
--视图

SELECT A.object_id AS ID
,'视图' sType
,A.Name --视图名
,B.definition Text --存储过程内容
FROM sys.views A
INNER JOIN sys.sql_modules B ON A.object_id=B.object_id
ORDER BY A.name
--存储过程
SELECT A.object_id AS ID
,'存储过程' sType
,A.Name --存储过程名称
,B.definition Text --存储过程内容
FROM sys.procedures A
INNER JOIN sys.sql_modules B ON A.object_id=B.object_id
ORDER BY A.name

数据库比对工具SQL(表、字段、触发器、索引、视图、存储过程)的更多相关文章

  1. SQL基础随记2 视图 存储过程

    SQL基础随记2 视图 存储过程   View CREATE/ALTER/DROP VIEW ViewName as SELECT(...) 可以在视图的基础上继续创建视图,即,将之前创建的视图当做表 ...

  2. SQL Server 优化---为什么索引视图(物化视图)需要with(noexpand)强制查询提示

    本文出处:http://www.cnblogs.com/wy123/p/6694933.html 第一次通过索引视图优化SQL语句,以及遇到的一些问题,记录一下. 语句分析 最近开发递交过来一个查询统 ...

  3. 数据库性能监测工具——SQL Server Profiler

    使用SQL Server Profiler 进行sql监控需要一些设置: 其他的就是进行分析了~ 清除SQL SERVER缓存 常用的方法: DBCC DROPCLEANBUFFERS 从缓冲池中删除 ...

  4. information_schema系列五(表,触发器,视图,存储过程和函数)

    这个系列的文章主要是为了能够让自己了解MySQL5.7的一些系统表,统一做一下备注和使用,也希望分享出来让大家能够有一点点的受益. 1:TABLES TABLES这张表毫无疑问了,就是记录的数据库中表 ...

  5. sql中的触发器、视图、事务

    ·触发器(trigger) [触发器本质上还是一个存储过程,只不过不是用exe来调用执行,而是通过增删改数据库的操作] [触发器只对增.删.改有效] 触发器的格式 (instead of与for的区别 ...

  6. 07_数据库创建,添加c3p0操作所需的jar包,编写c3p0-config.xml文件,编写User.java,编写jdbcUtils.java实现操作数据库的模板工具类,UserDao编写,Dao

     1  创建day14数据库,创建user.sql表: A 创建数据库 day14 B 创建数据表 users create table users ( id int primary keyaut ...

  7. SQL Server 索引视图 聚簇索引

    创建示例: 朋友的网站速度慢,让我帮忙看下,他用的SQL Server里面 有一个文章表里面有30多万条记录 还有一个用户表里面也差不多17万记录 偏偏当初设计的时候没有冗余字段 很多帖子信息需要JO ...

  8. 使用SQL Server 2000索引视图提高性能

    什么是索引视图? 许多年来,Microsoft? SQL Server? 一直都提供创建虚拟表(称为视图)的功能.在过去,这些视图主要有两种用途: 提供安全机制,将用户限制在一个或多个基表中的数据的某 ...

  9. SQL Server索引视图以(物化视图)及索引视图与查询重写

    本位出处:http://www.cnblogs.com/wy123/p/6041122.html 经常听Oracle的同学说起来物化视图,物化视图的作用之一就是可以实现查询重写,听起来有一种高大上的感 ...

随机推荐

  1. 用transform和rem哪个好

    个人觉得电脑端的用transform好,毕竟电脑端的项目基本都会固定屏幕比列,16:9.28:9.32:9的 一个固定的设计稿就能很好的适配. 移动端用rem比较好,移动端的屏幕比列太杂,使用rem自 ...

  2. js关于数组的操作(合并数组、添加数组、循环等)

    1. concat() 方法 concat() 方法用于连接两个或多个数组 var arr = new Array(3) arr[0] = "George" arr[1] = &q ...

  3. .NET Worker Service 部署到 Linux 作为 Systemd Service 运行

    上一篇文章我们了解了如何将.NET Worker Service 作为 Windows 服务运行,今天我接着介绍一下如何将 Worker Service 部署到 Linux 上,并作为 Systemd ...

  4. ClickHouse学习系列之六【访问权限和账户管理】

    背景 在之前写的文章[用户权限管理]里已经介绍了应该如何设置用户密码以及权限控制.但是只是针对修改配置文件的方式来进行用户权限管理,其实ClickHouse也支持基于RBAC(Role-Based A ...

  5. QGIS如何打开ArcGIS创建的GDB数据库文件

    引言 QGIS作为一种开源的地理信息处理软件由于其界面友好.渲染速度快.开源免费等特性而获得业内很多人士的青睐,然而在实际的生产和处理过程中,GIS数据往往存储在ArcGIS的文件地理数据库(Geod ...

  6. css 小细节

    1.div 设置background-image 图片,显示不全问题:background-size:100% 100%;

  7. Pygame 入门基本指南

    最近正在利用 Python 制作一个小游戏,但对于 Pygame 不熟悉,故在学习的过程记录相关知识点 Pygame 中文文档下载:Here Pygame第1-1课:入门 什么是Pygame? Pyg ...

  8. Springboot:SpringBoot2.0整合WebSocket,实现后端数据实时推送!

    一.什么是WebSocket? B/S结构的软件项目中有时客户端需要实时的获得服务器消息,但默认HTTP协议只支持请求响应模式,这样做可以简化Web服务器,减少服务器的负担,加快响应速度,因为服务器不 ...

  9. Windows10:虚拟机开机导致win10黑屏、蓝屏

    管理员身份打开cmd(命令提示符) 执行如下5个命令 netsh winsock reset net stop VMAuthdService net start VMAuthdService net ...

  10. vim 知识点小结

    vim用法可以学习:vim用法 Vim修改tab为4个空格 vi /etc/vim/vimrc 添加:set ts=4 vim中翻页的快捷键:向上翻页 ctrl+b,向下翻页 ctrl+f vim替换 ...