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

相关文章

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

Python中win32包的安装及常见用途介绍

《Python中win32包的安装及常见用途介绍》在Windows环境下,PythonWin32模块通常随Python安装包一起安装,:本文主要介绍Python中win32包的安装及常见用途的相关... 目录前言主要组件安装方法常见用途1. 操作Windows注册表2. 操作Windows服务3. 窗口操作

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方

MySQL中的索引结构和分类实战案例详解

《MySQL中的索引结构和分类实战案例详解》本文详解MySQL索引结构与分类,涵盖B树、B+树、哈希及全文索引,分析其原理与优劣势,并结合实战案例探讨创建、管理及优化技巧,助力提升查询性能,感兴趣的朋... 目录一、索引概述1.1 索引的定义与作用1.2 索引的基本原理二、索引结构详解2.1 B树索引2.2

如何使用Maven创建web目录结构

《如何使用Maven创建web目录结构》:本文主要介绍如何使用Maven创建web目录结构的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录创建web工程第一步第二步第三步第四步第五步第六步第七步总结创建web工程第一步js通过Maven骨架创pytho

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h

Python循环结构全面解析

《Python循环结构全面解析》循环中的代码会执行特定的次数,或者是执行到特定条件成立时结束循环,或者是针对某一集合中的所有项目都执行一次,这篇文章给大家介绍Python循环结构解析,感兴趣的朋友跟随... 目录for-in循环while循环循环控制语句break语句continue语句else子句嵌套的循

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.