[SPLEB]CodeSmith原理剖析(2)

简介:

三,         SchemaExplorer,数据库访问

CodeSmith 之所以如此强大的原因,即提供了方便的数据库访问和调用。此部分其实可以算是一个插件,即SchemaExplorer

SchemaExplorer封装了所有数据库对象。提供了DatabaseSchemaTableSchemaColumnSchema等的数据库Schema,并且采用动态加载Assembly的方法提供了对数据源信息的提取,该功能由IDbSchemaProvider接口实现。在CodeSmith的网站上提供了许多组件。V3.1提供了ADOXSchemaProviderSqlSchemaProvider,用于对ADOSql数据库的访问,类似ADO.NET中的OleDbDataAdpaterSqlDataAdpater

DatabaseSchema代表一个数据库。根据ConnnectionStringIDbSchemaProvider进行构造。其主要的属性是TableSchmeaCollectionViewSchemaCollection,提供了该数据库的数据表和数据视图信息。

TableSchema代表一个数据库表。主要是提供了ColumnSchemaCollection。即数据表的列数据。

ColumnSchema代表一个数据表的列。主要属性是ColumnNameSystemTypeColumnTypeIsPrimaryKeyMember等内容

以上三各类都提供了ExtendedPropertyCollection,储存扩展信息,该集合类似HashTable,另外,很多数据库Provider提供的该类性的数据库的特殊信息也储存此处。

在模板中,可以通过迭代以上三各类的集合类,对数据库的存储过程,ORM等进行全自动生成。

本文转自冬冬博客园博客,原文链接:http://www.cnblogs.com/yuandong/archive/2006/02/04/325272.html ,如需转载请自行联系原作者
相关文章
|
安全 Java 网络安全
给企业邮箱发送邮件失败
## 一、背景 在项目开发过程中,涉及到一个给企业邮箱发送邮件的功能,但在写完相关的邮件发送代码之后,出现问题,邮件发送失败。其中,邮件发送的相关代码如下: ```java JavaMailSenderImpl javaMailSender = new JavaMailSenderImpl(); javaMailSender.setHost("smtp.aliyun.com"); javaMail
1215 0
|
Linux Shell
阿里云服务器+安装宝塔
阿里云服务器+安装宝塔
816 1
阿里云服务器+安装宝塔
|
算法 C++ 容器
C++标准库(速查)总结
C++标准库(速查)总结
318 6
|
人工智能 小程序 搜索推荐
uni app下开发AI运动小程序解决方案
本文介绍了在小程序中实现AI运动识别的解决方案。该方案依托于UNI平台,通过高效便捷的插件形式,实现包括相机抽帧控制、人体识别、姿态识别等在内的多项功能,无需依赖后台服务器,大幅提高识别效率和用户体验。方案内置多种运动模式,支持自定义扩展,适用于AI健身、云上赛事、AI体测等多场景,适合新开发和存量改造项目。
|
敏捷开发 Kubernetes 测试技术
阿里云云效产品使用合集之开启分支或标签过滤功能在哪里使用
云效作为一款全面覆盖研发全生命周期管理的云端效能平台,致力于帮助企业实现高效协同、敏捷研发和持续交付。本合集收集整理了用户在使用云效过程中遇到的常见问题,问题涉及项目创建与管理、需求规划与迭代、代码托管与版本控制、自动化测试、持续集成与发布等方面。
|
数据可视化 PyTorch 算法框架/工具
Transformers 4.37 中文文档(五)(3)
Transformers 4.37 中文文档(五)
198 0
|
自然语言处理 Android开发 Windows
文本----搜狗如何使用日语输入法,日本本土使用人数最多输入法Simeji Japanese Input + Emoji,Windows10如何添加日语输入法,Windows + 空格选择语言,谷歌公
文本----搜狗如何使用日语输入法,日本本土使用人数最多输入法Simeji Japanese Input + Emoji,Windows10如何添加日语输入法,Windows + 空格选择语言,谷歌公
|
SQL Oracle 关系型数据库
技术心得:数据库之笛卡尔积
技术心得:数据库之笛卡尔积
501 0
|
Kubernetes 网络安全 Windows
要在云效部署到阿里云服务器上的 Windows Server 上的 IIS
【2月更文挑战第18天】要在云效部署到阿里云服务器上的 Windows Server 上的 IIS
742 4
|
JSON 缓存 NoSQL
重新更新VScode配置(C/C++)——负责任、手把手教学,亲测有效
对于C/C++的编程环境来说,目前我们所接触到的、所用到的,除了vim以外,大众用的、尤其是学生群体用的主要是有三种。
1793 1
重新更新VScode配置(C/C++)——负责任、手把手教学,亲测有效