CodeDom六--实体类生成示例
CodeDom这个东西个人觉得知识点不多,前几个续节写的已差不多了。在这节将演示一个CodeDom示例:
数据库实体类的生成。这里先声明在如今的CodeSmith或者是T4模板中实现这些都很简单,并且更实用,在这
里只是一个CodeDom示例,为了演示CodeDom。
在代码中位了简单、简化数据库数据信息的提取,引用了CodeSimth的SchemaExplorer.dll和SchemaExplorer.
SqlSchemaProvider.dll。可以在Demo中的CodeSimth目录下找到。
先贴上代码,需要讲解的东西没有什么:
using System;
using System.Text;
using System.Windows.Forms;
using SchemaExplorer;
using System.CodeDom;
using System.CodeDom.Compiler;
namespace CodeDomDemo
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
IDbSchemaProvider provider = new SqlSchemaProvider();
string connectionString = System.Configuration.ConfigurationManager.
|
- ?
- AppSettings["ConnectionString"].ToString();
- if (string.IsNullOrEmpty(connectionString))
- {
- MessageBox.Show(this, "Connection String is requested,in app configuration.",
- ?
- "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
- Application.Exit();
- }
- DatabaseSchema db = new DatabaseSchema(provider, connectionString);
- lboxTables.Items.AddRange(db.Tables.ToArray());
- }
- ?
- public CodeCompileUnit GenTableCompilerUnit(TableSchema item)
- {
- if (item == null)
- throw new ArgumentNullException("item");
- CodeTypeDeclaration tableClass = new CodeTypeDeclaration();
- tableClass.Attributes = MemberAttributes.Public | MemberAttributes.Final;
- tableClass.Name = item.Name;
- ?
- foreach (var col in item.Columns)
- {
- CodeMemberField field = new CodeMemberField(
- ?
- new CodeTypeReference(col.SystemType), "_" + col.Name);
- CodeMemberProperty property = new CodeMemberProperty();
- property.Name = col.Name;
- property.Attributes = MemberAttributes.Public | MemberAttributes.Final;
- property.Type = new CodeTypeReference(col.SystemType);
- property.SetStatements.Add(new CodeAssignStatement(
- ?
- new CodeFieldReferenceExpression(new CodeThisReferenceExpression(),
- field.Name), new CodePropertySetValueReferenceExpression()));
- property.GetStatements.Add(new CodeMethodReturnStatement(
- ?
- new CodeFieldReferenceExpression(new CodeThisReferenceExpression(), field.Name)));
- tableClass.Members.Add(field);
- tableClass.Members.Add(property);
- }
- CodeNamespace nspace = new CodeNamespace(item.Database.Name);
- nspace.Imports.Add(new CodeNamespaceImport("System"));
- nspace.Types.Add(tableClass);
- CodeCompileUnit unit=new CodeCompileUnit();
- unit.Namespaces.Add(nspace);
- return unit;
- }
- public string GenTanleCodeFromCompilerUnit(CodeCompileUnit unit, string language)
- {
- CodeGeneratorOptions option=new CodeGeneratorOptions();
- option.BlankLinesBetweenMembers =true;
- option.BracingStyle ="c";
- option.ElseOnClosing=true;
- option.IndentString=" ";
- StringBuilder sb=new StringBuilder();
- System.IO.StringWriter sw=new System.IO.StringWriter(sb);
- CodeDomProvider.CreateProvider(language).GenerateCodeFromCompileUnit(unit, sw, option);
- sw.Close();
- return sb.ToString();
- }
- ?
private void lboxTables_SelectedIndexChanged(object sender, EventArgs e)
{
int index = lboxTables.SelectedIndex;
if (index > -1 && index < lboxTables.Items.Count)
{
object obj = lboxTables.Items[index];
if (obj is TableSchema)
{
CodeCompileUnit unit= GenTableCompilerUnit(obj as TableSchema);
string language="c#";
if(!string.IsNullOrEmpty(this.toolStripComboBox1.Text))
language=this.toolStripComboBox1.Text;
string code = GenTanleCodeFromCompilerUnit(unit,language);
this.rtbCode.Text = code;
}
}
}
}
}
|
代码比较简单界面也做得太简洁了,呵呵导出文件都没有,我觉得没有什么必要讲解的,如果有什么不懂的或者是写的不对
不好的,请留言,我会尽快回复。
CodeDom代码下载;
转载于:https://blog.51cto.com/whitewolfblog/834669
CodeDom六--实体类生成示例相关推荐
- c mysql实体类生成工具_【干货分享】C# 实体类生成工具
前言: 项目实战中不论是业务编码还是通用编码,总会归纳出一些通用的工具类.放入项目中一劳永逸,让兄弟姐妹们避免编写重复代码.所以利用了工作之余的时间,将这些散落在多个项目中精致优雅的工具类,归纳起来形 ...
- [开源] FreeSql.AdminLTE.Tools 根据实体类生成后台管理代码
前言 FreeSql 发布至今已经有9个月,功能渐渐完善,自身的生态也逐步形成,早在几个月前写过一篇文章<ORM 开发环境之利器:MVC 中间件 FreeSql.AdminLTE>,您可以 ...
- java实体类生成mysql表_springboot+mybatis通过实体类自动生成数据库表的方法
前言 本章介绍使用mybatis结合mysql数据库自动根据实体类生成相关的数据库表. 首先引入相关的pom包我这里使用的是springboot2.1.8.RELEASE的版本 org.mybatis ...
- 根据java实体类生成创建表sql步骤
根据java实体类生成创建表sql步骤 根据java实体类生成创建表sql语句时,方法是利用java反射+AOP注解,主要步骤如下: 1.注解类 一般在生成表的时候,需要表名.主键名.字段名,对应到注 ...
- Springboot根据实体类生成数据库表
springboot数据库(一)-springboot-JPA JPA:springboot -jpa:数据库的一系列的定义数据持久化的标准的体系 学习的目的是: 利用springboot实现对数据库 ...
- 根据实体类生成数据库表
参考文档地址:通过实体类生成数据库表_weixin_44571808的博客-CSDN博客_java实体类生成数据库表 注意springboot版本号需要比较低(没有详细测试2.6不行,2.1.11可以 ...
- 根据实体类生成持久层、控制层、服务层、实现层
最近写个java web 程序,用的spring boot.spring data jpa 由于数据库表较多.逆向工程生成的实体类也比较多,重复性工作就很多也很枯燥,今天把重复部分提取出来,用代码自动 ...
- EntityFramework实体框架—反向工程(实体类生成)
文章目录 前言 1. Entity Framework Core反向工程定义 2.实现工作原理 3.准备工作 4. 编写命令 前言 Entity Framework Core 是适用于 .NET 的新 ...
- Spring Boot配置Mysql后无法根据java实体类生成table
https://www.imooc.com/qadetail/193270?t=292816 检查了两天,没找到问题.原因为实体类必须在主程序application的同名包或者子包下面,启动时才会扫描 ...
最新文章
- Battle for Wesnoth 1.8.4,开源战斗游戏
- 简单团队-爬取豆瓣电影TOP250-需求分析
- klee错误汇报二:KLEE的optimize选项的一个困惑
- 利用多线程解决多业务不同定时区间歇触发问题的一种方法
- ML顶会论文都可复现吗?来挑战一下,还能拿500美元补贴
- 网站服务器日志都有哪些,网站服务器日志在哪里看?
- 月份java题_Java基础50道经典练习题(14)——求日期
- Git 分支 - 分支的新建与合并
- phpmyadmin忘记mysql密码_忘记phpmyadmin登录密码怎么办
- scss 里的 Mixins 用法介绍
- linux下c和c++互相调用
- 如何不部署Keras / TensorFlow模型
- Android开发中目前流行控件和知识点总结
- colorpix取色小工具_五款互联网人必备的免费工具,超级实用
- 美工设计灵感|常见的电商页面如何设计?
- MyBatis-Plus通过注解的方式绑定一对多查询
- 双层板在哪层覆铜_2020年中国印制电路板行业发展现状及发展趋势预测(图)...
- ARTPI(STM32H750XBH) + ALIENTEK 7‘ RGB TFTLCD + LVGL8.2.0成功
- 我国IPTV研究目前已达到全球领先水平
- 系统安全——Windows中的共享文件和文件服务器