CodeSmith----SchemaExplorer类结构详细介绍

2024-04-21 04:48

本文主要是介绍CodeSmith----SchemaExplorer类结构详细介绍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CodeSmith与数据库的联系,在CodeSmith中自带一个程序集SchemaExplorer.dll,这个程序集中的类主要用于获取数据库中各种对象的结构。

 

<%@ Property Name="SourceTable" Type="SchemaExplorer.TableSchema" Default="" Optional="False" Category="Context" Description="源表名" %>

 

<%@ Property Name="SourceDB" Type="SchemaExplorer.DatabaseSchema" Default="" Optional="False" Category="Context" Description="" OnChanged="" Editor="" EditorBase="" Serializer="" %>

 

<%@ Assembly Name="SchemaExplorer" %>

 

<%@ Import Namespace="SchemaExplorer" %>

 

 

 

SchemaExplorer中主要类的结构和功能:

 

DatabaseSchema

 

属*:

 

ConnectionString:一般填写类似于ADO.NET的连接字符串

 

Name:数据库名称

 

Provider:驱动程序提供者,一般实例化一个SqlSchemaProvider对象

 

集合:

 

Commands:所有存储过程集合

 

Tables:所有表的集合

 

Views:所有视图的集合

 

 

 

TableSchema

 

属*:

 

Name:表名

 

Database:所在数据库

 

DataCreated:创建日期

 

FullName:全名

 

HasPrimaryKey:是否有主键

 

Owner:所有者

 

PrimaryKey:主键信息

 

 

 

方法:GetTableData:获取表中所有数据,结果为DataTable

 

 

 

集合:

 

Columns:所有列集合

 

ForeignKeyColumns:所有外键列的集合

 

ForeignKeys:外键信息的集合

 

Indexes:所有索引的信合

 

Keys:所有主键和外键的列的集合

 

NonKeyColumns:所有非主键外键列的集合

 

NonForeignKeyColumns:所有非外键列的集合

 

NonPrimaryKeyColumns:所有非主键列的集合

 

PrimaryKeys:主键信息的集合

 

 

 

CommandSchema存储过程结构

 

属*:

 

Name:存储过程名

 

FullName:全名

 

Database:所在数据库

 

DataCreated:创建日期

 

Owner:所有者

 

ReturnValueParameter:返回值参数,SQLSERVER中似乎取不到

 

CommandText:存储过程的内容源代码

 

 

 

集合:

 

AllInputParameters:所有的输入参数集合,有可能包括即是输入又是输出的参数

 

AllOutputParameters:所有输出参数的集合,有可能包括即是输入又是输出的参数

 

CommandResults:存储过程的查询结果集合

 

InputOutputParameters:输入输出参数的集合

 

InputParameters:所有输入参数的集合

 

OutputParameters:所有输出参数的集合

 

Parameters:所有参数的集合

 

NonReturnValueParameters:除了返回值之外的参数的集合

 

 

 

ViewSchema视图结构

 

属*:

 

Name:视图名

 

FullName:视图全名

 

Database:所在数据库

 

DataCreated:创建日期

 

Owner:所有者

 

ViewText:视图源代码

 

 

 

方法:GetViewData:得到视图中的数据,返回类型为DataTable

 

 

 

集合:Columns:视图中所有列的集合

 

 

 

ColumnSchema列结构

 

属*:

 

Name:列的名称

 

NonDBNull:是否允许为空

 

Database:所在数据库

 

DataType:内部表示的数据类型

 

IsForeignKeyMember:是否为外键

 

IsPrimaryKeyMember:是否为主键,通用

 

IsUnique:是否唯一

 

NativeType:数据库中的数据类型

 

Precision:精度

 

Scale:小数位数

 

Size:列的长度

 

SystemType:当前列在所用语言中的类型

 

Table:所在的表

 

 

 

ParameterSchema参数结构

 

属*:

 

Name:参数名称

 

NonDBNull:是否为空

 

Command:所在存储过程名

 

Database:所在数据库

 

Direction:参数的类型:输入,输出,输入输出,返回值

 

NativeType:数据库中的数据类型

 

Size:长度

 

Precision:精度

 

Scale:小数位数

 

SystemType:当前列在所用语言中的类型

 

 

 

ViewColumnSchema视图列的结构

 

属*:

 

Name:视图的名称

 

NonDBNull:是否为空

 

View:所在的视图

 

Database:所在的数据库

 

NativeType:SqlServer中的类型

 

Size:长度

 

Precision:精度

 

Scale:小数位数

 

SystemType:当前列在所用语言中的类型

 

 

 

TableKeySchema表中键结构

 

属*:

 

Name:表的键的名称,即约束名称

 

Database:所在数据库

 

ForeignKeyTable:有外键的表,即子表

 

PrimaryKeyTable:主键表,即主表

 

PrimaryKey:主表的主键信息

 

 

 

集合:

 

PrimaryKeyMemberColumns:当前键信息中主键的成员列集合,即主表中的主键的列的集合

 

ForeignKeyMemberColumns:当前键信息中外键的成员列集合,即子表中某个外键的列集合

 

 

 

IndexSchema索引的结构

 

属*:

 

Name:索引名称

 

Table:所在表

 

DataBase:所在数据库

 

Is:是否聚集索引

 

IsPrimaryKey:是否为主键索引

 

IsUnique:是否为唯一索引

 

 

 

集合:MemberColumns:索引的列集合

 

 

 

ExtendedProperty扩展信息

 

Table:

 

CS_isIdentity:是否为标识符,不支持Access

 

CS_isComputed:是否为计算列

 

CS_isDeterministic:是否确定...

 

CS_IdentitySeed::标识列种子数

 

CS_IdentityIncrement:标识列递增量

 

CS_Default:列的默认值 

 

CS_isRowGuidCol

 

 

 

View:

 

CS_isComputed:是否为计算列

 

CS_isDeterministic:

 

 

 

Command:

 

CS_Default:存储过程的默认参数

 

 

这篇关于CodeSmith----SchemaExplorer类结构详细介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/922186

相关文章

ubuntu20.0.4系统中安装Anaconda的超详细图文教程

《ubuntu20.0.4系统中安装Anaconda的超详细图文教程》:本文主要介绍了在Ubuntu系统中如何下载和安装Anaconda,提供了两种方法,详细内容请阅读本文,希望能对你有所帮助... 本文介绍了在Ubuntu系统中如何下载和安装Anaconda。提供了两种方法,包括通过网页手动下载和使用wg

SpringBoot实现二维码生成的详细步骤与完整代码

《SpringBoot实现二维码生成的详细步骤与完整代码》如今,二维码的应用场景非常广泛,从支付到信息分享,二维码都扮演着重要角色,SpringBoot是一个非常流行的Java基于Spring框架的微... 目录一、环境搭建二、创建 Spring Boot 项目三、引入二维码生成依赖四、编写二维码生成代码五

Java中 instanceof 的用法详细介绍

《Java中instanceof的用法详细介绍》在Java中,instanceof是一个二元运算符(类型比较操作符),用于检查一个对象是否是某个特定类、接口的实例,或者是否是其子类的实例,这篇文章... 目录引言基本语法基本作用1. 检查对象是否是指定类的实例2. 检查对象是否是子类的实例3. 检查对象是否

将图片导入Python的turtle库的详细过程

《将图片导入Python的turtle库的详细过程》在Python编程的世界里,turtle库以其简单易用、图形化交互的特点,深受初学者喜爱,随着项目的复杂度增加,仅仅依靠线条和颜色来绘制图形可能已经... 目录开篇引言正文剖析1. 理解基础:Turtle库的工作原理2. 图片格式与支持3. 实现步骤详解第

Docker安装MySQL镜像的详细步骤(适合新手小白)

《Docker安装MySQL镜像的详细步骤(适合新手小白)》本文详细介绍了如何在Ubuntu环境下使用Docker安装MySQL5.7版本,包括从官网拉取镜像、配置MySQL容器、设置权限及内网部署,... 目录前言安装1.访问docker镜像仓库官网2.找到对应的版本,复制右侧的命令即可3.查看镜像4.启

Java版本不兼容问题详细解决方案步骤

《Java版本不兼容问题详细解决方案步骤》:本文主要介绍Java版本不兼容问题解决的相关资料,详细分析了问题原因,并提供了解决方案,包括统一JDK版本、修改项目配置和清理旧版本残留等步骤,需要的朋... 目录错误原因分析解决方案步骤第一步:统一 JDK 版本第二步:修改项目配置第三步:清理旧版本残留兼容性对

exfat和ntfs哪个好? U盘格式化选择NTFS与exFAT的详细区别对比

《exfat和ntfs哪个好?U盘格式化选择NTFS与exFAT的详细区别对比》exFAT和NTFS是两种常见的文件系统,它们各自具有独特的优势和适用场景,以下是关于exFAT和NTFS的详细对比... 无论你是刚入手了内置 SSD 还是便携式移动硬盘或 U 盘,都需要先将它格式化成电脑或设备能够识别的「文

什么是ReFS 文件系统? ntfs和refs的优缺点区别介绍

《什么是ReFS文件系统?ntfs和refs的优缺点区别介绍》最近有用户在Win11Insider的安装界面中发现,可以使用ReFS来格式化硬盘,这是不是意味着,ReFS有望在未来成为W... 数十年以来,Windows 系统一直将 NTFS 作为「内置硬盘」的默认文件系统。不过近些年来,微软还在研发一款名

史上最全nginx详细参数配置

《史上最全nginx详细参数配置》Nginx是一个轻量级高性能的HTTP和反向代理服务器,同时也是一个通用代理服务器(TCP/UDP/IMAP/POP3/SMTP),最初由俄罗斯人IgorSyso... 目录基本命令默认配置搭建站点根据文件类型设置过期时间禁止文件缓存防盗链静态文件压缩指定定错误页面跨域问题

nginx负载均衡及详细配置方法

《nginx负载均衡及详细配置方法》Nginx作为一种高效的Web服务器和反向代理服务器,广泛应用于网站的负载均衡中,:本文主要介绍nginx负载均衡及详细配置,需要的朋友可以参考下... 目录一、 nginx负载均衡策略1.1 基本负载均衡策略1.2 第三方策略1.3 策略对比二、 nginx配置2.1