SQL点滴之筛选数据列的信息

数据库 SQL Server
前面两次点滴分享中,笔者与我们分享了SET QUOTED_IDENTIFIER 的作用,并给我们介绍了一个简单的字符串分割函数。这一次,笔者为我们介绍怎么从SQL Server中找出所有的数据列的类型,字段大小,是否可为空,是否是主键,约束等等信息。

前面两次点滴分享中,笔者与我们分享了SET QUOTED_IDENTIFIER 的作用,并给我们介绍了一个简单的字符串分割函数。这一次,笔者为我们介绍怎么从SQL Server中找出所有的数据列的类型,字段大小,是否可为空,是否是主键,约束等等信息。

项目需要将Access数据库中的数据导入到SQL Server中,需要检验导入后的数据完整性,数据值是否正确。我们使用的是Microsoft SQL Server 2008 Migration Assistant for Access这个工具,次工具专门用来将Access中的数据库导出到SQL Server中,我们的疑虑是这个导出过程中会不会因为认为的原因导致数据错误或者数据之间的关联丢失,看起来有点多次一举,但是还是找方法来做测试。于是就产生了今天的问题,怎么从SQL Server中找出所有的数据列的类型,字段大小,是否可为空,是否是主键,约束等等信息。我找很多资料鼓捣出这个存储过程,先来看看代码:

  1. USE [MIS]  
  2. GO  
  3.  
  4. /****** Object:  StoredProcedure [dbo].[sp_SelectColumnInfor]    Script Date: 09/23/2010 19:00:28 ******/  
  5. SET ANSI_NULLS ON 
  6. GO  
  7.  
  8. SET QUOTED_IDENTIFIER ON 
  9. GO  
  10.  
  11. create procedure [dbo].[sp_SelectColumnInfor]  
  12. as 
  13. declare @table_name varchar(250)  
  14. --create a temp table  
  15. create table #tempTable(  
  16. TABLE_NAME nvarchar(128),  
  17. COLUMN_NAME nvarchar(128),  
  18. IS_NULLABLE varchar(3),  
  19. DATA_TYPE nvarchar(128),  
  20. CHARACTER_MAXIMUM_LENGTH int,  
  21. CONSTRAINT_NAME nvarchar(128),  
  22. )   
  23. --create a cursor  
  24. declare curTABLE cursor for 
  25. select TABLE_NAME from INFORMATION_SCHEMA.TABLES where TABLE_TYPE='BASE TABLE' 
  26. for read only 
  27.  
  28. open curTABLE  
  29. fetch next from curTABLE into @table_name  
  30. while @@FETCH_STATUS =0  
  31. begin 
  32. insert into #tempTable  
  33. select sc.[TABLE_NAME],sc.[COLUMN_NAME],sc.[IS_NULLABLE],sc.[DATA_TYPE],sc.[CHARACTER_MAXIMUM_LENGTH]  
  34. ,scc.CONSTRAINT_NAME  
  35. from INFORMATION_SCHEMA.COLUMNS sc   
  36. left join INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE scc on sc.COLUMN_NAME=scc.COLUMN_NAME and sc.TABLE_NAME=scc.TABLE_NAME  
  37. where sc.[TABLE_NAME]=@table_name --order by TABLE_NAME,COLUMN_NAME  
  38.  
  39. fetch next from curTABLE into @table_name  
  40. end 
  41. close curTABLE  
  42. deallocate curTABLE  
  43. select * from #tempTable order by TABLE_NAME,COLUMN_NAME  
  44. drop table #tempTable  
  45. GO 

 
其实很简单的,只要查查INFORMATION_SCHEMA.COLUMNS , INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE这两个系统视图的功能就能明白。来看看执行这个存储过程得到的结果:

 

 下次介绍Microsoft SQL Server 2008 Migration Assistant for Access这个工具的用法。

 原文链接:http://www.cnblogs.com/tylerdonet/archive/2010/09/23/1833381.html

【编辑推荐】

  1. SQL点滴之SET QUOTED_IDENTIFIER OFF语句的作用
  2. SQL点滴之一个简单的字符串分割函数
  3. 微博 请问你是怎么优化数据库的?
  4. MySQL数据库的优化(上)单机MySQL数据库的优化
  5. MySQL数据库的优化(下)MySQL数据库的高可用架构方案

 

责任编辑:艾婧 来源: 博客园
相关推荐

2011-05-11 09:49:32

线程等待SQL Server

2011-06-23 14:00:51

SQL点滴

2011-09-13 10:25:05

数据库点滴

2011-09-09 10:10:13

SQL数据库点滴

2011-08-02 13:04:40

SQL Server

2011-05-06 16:36:48

SQL备份还原

2011-04-27 16:09:48

SQL ServerSSIS

2011-04-27 14:27:11

SQL Server

2011-10-09 16:40:50

T-SQL

2011-08-03 13:32:00

SQL Server优化

2011-04-20 11:11:33

SQLSET QUOTED_

2011-04-28 09:49:56

SQLwith子查询

2011-04-22 15:00:22

SQLwin7登录

2011-04-21 13:49:29

dementionSQL

2010-07-22 10:38:12

SQL Server所

2011-04-27 16:34:06

withSQL Server

2011-02-25 17:00:25

SQL闰年

2011-04-27 13:21:59

SQL Serverattach

2010-09-06 11:57:33

sql server语句

2011-04-27 15:55:16

点赞
收藏

51CTO技术栈公众号