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.

  1. ?
  2. AppSettings["ConnectionString"].ToString();
  3. if (string.IsNullOrEmpty(connectionString))
  4. {
  5. MessageBox.Show(this, "Connection String is requested,in app configuration.",
  6. ?
  7. "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
  8. Application.Exit();
  9. }
  10. DatabaseSchema db = new DatabaseSchema(provider, connectionString);
  11. lboxTables.Items.AddRange(db.Tables.ToArray());
  12. }
  13. ?
  14. public CodeCompileUnit GenTableCompilerUnit(TableSchema item)
  15. {
  16. if (item == null)
  17. throw new ArgumentNullException("item");
  18. CodeTypeDeclaration tableClass = new CodeTypeDeclaration();
  19. tableClass.Attributes = MemberAttributes.Public | MemberAttributes.Final;
  20. tableClass.Name = item.Name;
  21. ?
  22. foreach (var col in item.Columns)
  23. {
  24. CodeMemberField field = new CodeMemberField(
  25. ?
  26. new CodeTypeReference(col.SystemType), "_" + col.Name);
  27. CodeMemberProperty property = new CodeMemberProperty();
  28. property.Name = col.Name;
  29. property.Attributes = MemberAttributes.Public | MemberAttributes.Final;
  30. property.Type = new CodeTypeReference(col.SystemType);
  31. property.SetStatements.Add(new CodeAssignStatement(
  32. ?
  33. new CodeFieldReferenceExpression(new CodeThisReferenceExpression(),
  34. field.Name), new CodePropertySetValueReferenceExpression()));
  35. property.GetStatements.Add(new CodeMethodReturnStatement(
  36. ?
  37. new CodeFieldReferenceExpression(new CodeThisReferenceExpression(), field.Name)));
  38. tableClass.Members.Add(field);
  39. tableClass.Members.Add(property);
  40. }
  41. CodeNamespace nspace = new CodeNamespace(item.Database.Name);
  42. nspace.Imports.Add(new CodeNamespaceImport("System"));
  43. nspace.Types.Add(tableClass);
  44. CodeCompileUnit unit=new CodeCompileUnit();
  45. unit.Namespaces.Add(nspace);
  46. return unit;
  47. }
  48. public string GenTanleCodeFromCompilerUnit(CodeCompileUnit unit, string language)
  49. {
  50. CodeGeneratorOptions option=new CodeGeneratorOptions();
  51. option.BlankLinesBetweenMembers =true;
  52. option.BracingStyle ="c";
  53. option.ElseOnClosing=true;
  54. option.IndentString="    ";
  55. StringBuilder sb=new StringBuilder();
  56. System.IO.StringWriter sw=new System.IO.StringWriter(sb);
  57. CodeDomProvider.CreateProvider(language).GenerateCodeFromCompileUnit(unit, sw, option);
  58. sw.Close();
  59. return sb.ToString();
  60. }
  61. ?
        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六--实体类生成示例相关推荐

  1. c mysql实体类生成工具_【干货分享】C# 实体类生成工具

    前言: 项目实战中不论是业务编码还是通用编码,总会归纳出一些通用的工具类.放入项目中一劳永逸,让兄弟姐妹们避免编写重复代码.所以利用了工作之余的时间,将这些散落在多个项目中精致优雅的工具类,归纳起来形 ...

  2. [开源] FreeSql.AdminLTE.Tools 根据实体类生成后台管理代码

    前言 FreeSql 发布至今已经有9个月,功能渐渐完善,自身的生态也逐步形成,早在几个月前写过一篇文章<ORM 开发环境之利器:MVC 中间件 FreeSql.AdminLTE>,您可以 ...

  3. java实体类生成mysql表_springboot+mybatis通过实体类自动生成数据库表的方法

    前言 本章介绍使用mybatis结合mysql数据库自动根据实体类生成相关的数据库表. 首先引入相关的pom包我这里使用的是springboot2.1.8.RELEASE的版本 org.mybatis ...

  4. 根据java实体类生成创建表sql步骤

    根据java实体类生成创建表sql步骤 根据java实体类生成创建表sql语句时,方法是利用java反射+AOP注解,主要步骤如下: 1.注解类 一般在生成表的时候,需要表名.主键名.字段名,对应到注 ...

  5. Springboot根据实体类生成数据库表

    springboot数据库(一)-springboot-JPA JPA:springboot -jpa:数据库的一系列的定义数据持久化的标准的体系 学习的目的是: 利用springboot实现对数据库 ...

  6. 根据实体类生成数据库表

    参考文档地址:通过实体类生成数据库表_weixin_44571808的博客-CSDN博客_java实体类生成数据库表 注意springboot版本号需要比较低(没有详细测试2.6不行,2.1.11可以 ...

  7. 根据实体类生成持久层、控制层、服务层、实现层

    最近写个java web 程序,用的spring boot.spring data jpa 由于数据库表较多.逆向工程生成的实体类也比较多,重复性工作就很多也很枯燥,今天把重复部分提取出来,用代码自动 ...

  8. EntityFramework实体框架—反向工程(实体类生成)

    文章目录 前言 1. Entity Framework Core反向工程定义 2.实现工作原理 3.准备工作 4. 编写命令 前言 Entity Framework Core 是适用于 .NET 的新 ...

  9. Spring Boot配置Mysql后无法根据java实体类生成table

    https://www.imooc.com/qadetail/193270?t=292816 检查了两天,没找到问题.原因为实体类必须在主程序application的同名包或者子包下面,启动时才会扫描 ...

最新文章

  1. Battle for Wesnoth 1.8.4,开源战斗游戏
  2. 简单团队-爬取豆瓣电影TOP250-需求分析
  3. klee错误汇报二:KLEE的optimize选项的一个困惑
  4. 利用多线程解决多业务不同定时区间歇触发问题的一种方法
  5. ML顶会论文都可复现吗?来挑战一下,还能拿500美元补贴
  6. 网站服务器日志都有哪些,网站服务器日志在哪里看?
  7. 月份java题_Java基础50道经典练习题(14)——求日期
  8. Git 分支 - 分支的新建与合并
  9. phpmyadmin忘记mysql密码_忘记phpmyadmin登录密码怎么办
  10. scss 里的 Mixins 用法介绍
  11. linux下c和c++互相调用
  12. 如何不部署Keras / TensorFlow模型
  13. Android开发中目前流行控件和知识点总结
  14. colorpix取色小工具_五款互联网人必备的免费工具,超级实用
  15. 美工设计灵感|常见的电商页面如何设计?
  16. MyBatis-Plus通过注解的方式绑定一对多查询
  17. 双层板在哪层覆铜_2020年中国印制电路板行业发展现状及发展趋势预测(图)...
  18. ARTPI(STM32H750XBH) + ALIENTEK 7‘ RGB TFTLCD + LVGL8.2.0成功
  19. 我国IPTV研究目前已达到全球领先水平
  20. 系统安全——Windows中的共享文件和文件服务器

热门文章

  1. 推荐一款思维在线思维导图,为什么?
  2. SQL SERVER游标浅析
  3. MySQL性能优化 分区
  4. spring boot admin 自定义
  5. 机器学习工程师 - Udacity 强化学习 Part Nine
  6. jenkins html报告不显示样式
  7. 80211n标准建链速率计算
  8. C# 读取word2003 并且显示在界面上的方法
  9. 路由器连接宽带(成功上网步骤方法)
  10. 用python做一个搜索引擎(Pylucene)