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

相关文章

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

图神经网络模型介绍(1)

我们将图神经网络分为基于谱域的模型和基于空域的模型,并按照发展顺序详解每个类别中的重要模型。 1.1基于谱域的图神经网络         谱域上的图卷积在图学习迈向深度学习的发展历程中起到了关键的作用。本节主要介绍三个具有代表性的谱域图神经网络:谱图卷积网络、切比雪夫网络和图卷积网络。 (1)谱图卷积网络 卷积定理:函数卷积的傅里叶变换是函数傅里叶变换的乘积,即F{f*g}

C++——stack、queue的实现及deque的介绍

目录 1.stack与queue的实现 1.1stack的实现  1.2 queue的实现 2.重温vector、list、stack、queue的介绍 2.1 STL标准库中stack和queue的底层结构  3.deque的简单介绍 3.1为什么选择deque作为stack和queue的底层默认容器  3.2 STL中对stack与queue的模拟实现 ①stack模拟实现

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

沁恒CH32在MounRiver Studio上环境配置以及使用详细教程

目录 1.  RISC-V简介 2.  CPU架构现状 3.  MounRiver Studio软件下载 4.  MounRiver Studio软件安装 5.  MounRiver Studio软件介绍 6.  创建工程 7.  编译代码 1.  RISC-V简介         RISC就是精简指令集计算机(Reduced Instruction SetCom

Mysql BLOB类型介绍

BLOB类型的字段用于存储二进制数据 在MySQL中,BLOB类型,包括:TinyBlob、Blob、MediumBlob、LongBlob,这几个类型之间的唯一区别是在存储的大小不同。 TinyBlob 最大 255 Blob 最大 65K MediumBlob 最大 16M LongBlob 最大 4G

arduino ide安装详细步骤

​ 大家好,我是程序员小羊! 前言: Arduino IDE 是一个专为编程 Arduino 微控制器设计的集成开发环境,使用起来非常方便。下面将介绍如何在不同平台上安装 Arduino IDE 的详细步骤,包括 Windows、Mac 和 Linux 系统。 一、在 Windows 上安装 Arduino IDE 1. 下载 Arduino IDE 打开 Arduino 官网