C# Code Builder V1.2 (C#代码生成器) 产生支持多种数据库的实体代码

简介:
 其实写一个代码生成器,作用不是很大的,通用性也不强的,因为代码生成器产生的代码毕竟不是灵活的,功能是有限的,而且这部分代码在整个软件工程中工作量只占很小的一部份,可能你写代码生成器花的时间还没有直接把代码Copy、Paste见效得快一些,而且自己写出来的代码,错误还比较少一些,想写成什么样就写成什么样。由于各个系统开发的底层、基础类库都不一样、定位、主导思想也不一致,往往会导致需要代码生成器需要产生的代码也不同,代码里存在个性化的需求因素比较多一些。
   以前我受到过很多人的批评,说我不用代码生成器、工作效率低,我想想大家都这么批评我,也应该有道理,由于最近无聊吧,这几天精力也比较旺盛心情也舒畅,花费了前后3天的业余时间,写了一个简单的代码生成器。
   我最近参加一个项目后,我上面所写的错误的观念得到了彻底的转变,因为你需要写上几十个类、每个类又有很多字段,看得你眼花缭乱,关系逻辑也不是很严密,说白了就是添加修改删除功能的比较多,而且项目也很紧急,你就不会有上面的想法了,更何况,你手上也没有兵,也没有助手,就需要你自己来写上几万行这样的代码,估计也没几个人能忍受一行行敲打代码了,这时代码成生器,真的太有存在的必要,而且能明显提高生产力。你可以一天之内轻松写好几万行代码,然后可以心安理得看看娱乐新闻了,好好休息吧。
   在多个人做同一个项目时由于每个人的编码习惯不一样,写出来的代码也千奇百怪,不符合公司的统一标准,这时代码生成器也能派上大用处,代码是自动生成的,自然会符合公司的规范了,设置连检查都不用检查了,全是生成出来的代码。
   我把原代码也公布出来,希望能给c#入门爱好者提供一些帮助及参考、让大家写出更规范的程序、做出高品质的项目。我的代码也难免有些错误及漏洞、希望大家能留言提出宝贵意见,我会逐步完善这个代码,希望能给更多人提供参考、给他们带来快乐。
  本代码生成器、需要与我前面发布的通用数据库访问类及相关配套的基础类库才可以运行,大家先当个参考程序吧。可以仿造一下,自己也来个入门级别的代码器。别人可能就会认为你挺厉害了。
 
以下图片为: 用PowerDesigner设计数据表的效果图及程序运行效果图。 
1) PowerDesigner 设计效果如下:
 
2) 生成单个C#程序源码效果图如下:
 
3) 批量生成C#程序文件效果如下:
 
4) 主程序也就466行,其中还有一些注释,排版中还有空行,代码很少:
 
5) 页面布局重新整理了一下,增加了一些图片按钮,更友善了一些:
要针对的需求如下:
01. 若软件项目比较庞大时,写一些实体类的重复工作量会比较大.有个高质量的生成器,每人每天产几千行代码, 挺爽的效率很高。
02. 年轻人都比较浮躁,都不愿意干重复劳动, 创造性的,又干不出来, 所以还得给同事提供一个生成器什么的, 提高提高工作效率。
03. 虽然该工具还未彻底商品化,但是不允许有Bug。
04. 要符合用户的操作习惯, 页面布局, 操作逻辑顺序要符合大家的习惯, 至少要从上到下从左到右吧。
05. 产生出的类代码,排版要比较合理,直接复制到开发环境就,能有比较好的排版效果。
06. 通过 PowerDesigner 设计产生的 PDM 表结构设计自动产生相关 C# 类代码。
07. 产生的类文件,可以支持多种数据库,例如 SQL Server、Oracle、Microsoft Office Access。
08. 常用的添加、删除、修改、按某些查询等方法能自动产生。
09. 服务程序与页面程序,不需要产生,需要程序员自己编写。
10. 产生的类文件,能指定输出目录,产生文件后,能自动保存文件,若目标文件已经存在,需要进行提醒。
11. 能保存页面的参数设置、能自动输出类文件,不需自己创建文件要复制粘贴等繁琐步骤。
12. 可以批量产生全部代码,不用一个个点击产生代码,简化繁琐操作。
13. 页面上的设置信息发生变化时,提醒是否保存当前设置。
14. 若生成的目标文件已经存在,需要提醒用户是否覆盖?产生几十个文件,
每个都需要提醒就残忍了,那就是你不对了。
15. 能从 SQL Server、Oracle 数据库设计文件产生实体代码。
16. 生成代码后,光标能停留在类名输入框上,因为你要创建这个类文件,需要复制类名做为文件名。
17. 设计数据库表名时,往往会用到_,产生类文件时,需要进行优化,去掉_。
18. 字段名,生成类属性时需要进行适当的优化。
19. 批量生成c#代码文件后,应该可以自动打开所设定的目录,好复制粘贴程序。
20. 页面被最大化时,页面布局不要太难看,要保持良好的布局。
21. 打开文件的夹, 应该有记忆功能, 下次重新打开时,能快速选择以前打开的目录。
22. 默认情况下, 获取计算机的公司名称、当前计算机的用户名做为公司及作者版权默认设置。
23. 默认年度为当前计算机日期部分的年,默认日期为期为计算机的日期。
24. 页面上的参数设置、需要进行检测、例如设定的目录是否存在,
设定的文件是否存在?有错误,需要进行提醒,不能随意清除用户设置。
25. 光标默认停留在 Tabels 列表框里,方便用户选择。
26. 适当进行美化,软件界面友善一些,容易亲近用户。
27. 单独保存文件功能实现,可以自己选择保存路径、默认文件名及自己设定文件名。
28. 页面功能部分的区块说明。
29. (若要商业化,这个是必须要满足的条件)能高亮显示关键字。

我很少一天写超过1000行的代码, 写好了这个成成器后, 我一天生成了6个类的相关文件, 数了一下代码
有几千行, 想想,我可以好几天不用干活了, 也挺爽的, 有机会, 我也给大家分享分享。
后面的几个功能正在完善中,我把部分代码项目代码贴出来给大家分享一下。

29 功能部分还未完成,空了就继续完善,有需要时做也来得及。
下载 源代码  c# 代码生成器 1.1 版本可供下载
将权限管理、工作流管理做到我能力的极致,一个人只能做好那么很少的几件事情。




本文转自 jirigala 51CTO博客,原文链接:http://blog.51cto.com/2347979/451746,如需转载请自行联系原作者
相关文章
|
7天前
|
C# 开发者
C# 一分钟浅谈:Code Contracts 与契约编程
【10月更文挑战第26天】本文介绍了 C# 中的 Code Contracts,这是一个强大的工具,用于通过契约编程增强代码的健壮性和可维护性。文章从基本概念入手,详细讲解了前置条件、后置条件和对象不变量的使用方法,并通过具体代码示例进行了说明。同时,文章还探讨了常见的问题和易错点,如忘记启用静态检查、过度依赖契约和性能影响,并提供了相应的解决建议。希望读者能通过本文更好地理解和应用 Code Contracts。
20 3
|
28天前
|
存储 SQL 关系型数据库
Mysql学习笔记(二):数据库命令行代码总结
这篇文章是关于MySQL数据库命令行操作的总结,包括登录、退出、查看时间与版本、数据库和数据表的基本操作(如创建、删除、查看)、数据的增删改查等。它还涉及了如何通过SQL语句进行条件查询、模糊查询、范围查询和限制查询,以及如何进行表结构的修改。这些内容对于初学者来说非常实用,是学习MySQL数据库管理的基础。
106 6
|
1月前
|
数据可视化 API PHP
学生信息管理系统-可视化-科目管理CRUD代码生成器
学生信息管理系统-可视化-科目管理CRUD代码生成器
34 5
|
1月前
|
SQL 关系型数据库 MySQL
创建SQL数据库的基本步骤与代码指南
在信息时代,数据管理显得尤为重要,其中数据库系统已成为信息技术架构的关键部分。而当我们谈论数据库系统时,SQL(结构化查询语言)无疑是其中最核心的工具之一。本文将详细介绍如何使用SQL创建数据库,包括编写相应的代码和必要的步骤。由于篇幅限制,本文可能无法达到您要求的2000字长度,但会尽量涵盖创建数
34 3
|
1月前
|
安全 算法 Java
数据库信息/密码加盐加密 —— Java代码手写+集成两种方式,手把手教学!保证能用!
本文提供了在数据库中对密码等敏感信息进行加盐加密的详细教程,包括手写MD5加密算法和使用Spring Security的BCryptPasswordEncoder进行加密,并强调了使用BCryptPasswordEncoder时需要注意的Spring Security配置问题。
116 0
数据库信息/密码加盐加密 —— Java代码手写+集成两种方式,手把手教学!保证能用!
|
1月前
|
SQL 缓存 大数据
C#高效处理大数据的批次处理,以及最好的数据库设计
C#高效处理大数据的批次处理,以及最好的数据库设计
56 0
|
2月前
|
SQL NoSQL Java
彻底革新你的数据库操作体验!Micronaut数据访问技巧让你瞬间爱上代码编写!
【9月更文挑战第10天】Java开发者们一直在寻找简化应用程序与数据库交互的方法。Micronaut作为一个现代框架,提供了多种工具和特性来提升数据访问效率。本文介绍如何使用Micronaut简化数据库操作,并提供具体示例代码。Micronaut支持JPA/Hibernate、SQL及NoSQL(如MongoDB),简化配置并无缝集成。通过定义带有`@Repository`注解的接口,可以实现Spring Data风格的命名查询。
58 6
|
2月前
|
前端开发 数据库
数据库表设计生成代码
BizWorks ToolKit插件集成Mybatis-Plus代码生成工具,支持从数据库表生成代码,便于研发过程中数据模型变更后的代码同步。本文介绍批量生成代码的方法、配置说明及项目示例。配置文件`*.mp.yaml`用于描述生成行为,可放置于`src/main/resource/bizworks/mybatis-plus/`路径下。配置包括数据库信息、输出目录及包名等。通过IDEA右键菜单即可启动代码生成。具体配置和示例详见文档。
34 2
|
2月前
|
SQL 存储 关系型数据库
C#一分钟浅谈:使用 ADO.NET 进行数据库访问
【9月更文挑战第3天】在.NET开发中,与数据库交互至关重要。ADO.NET是Microsoft提供的用于访问关系型数据库的类库,包含连接数据库、执行SQL命令等功能。本文从基础入手,介绍如何使用ADO.NET进行数据库访问,并提供示例代码,同时讨论常见问题及其解决方案,如连接字符串错误、SQL注入风险和资源泄露等,帮助开发者更好地利用ADO.NET提升应用的安全性和稳定性。
219 6
|
3月前
|
存储 SQL 安全
【数据库高手的秘密武器:深度解析SQL视图与存储过程的魅力——封装复杂逻辑,实现代码高复用性的终极指南】
【8月更文挑战第31天】本文通过具体代码示例介绍 SQL 视图与存储过程的创建及应用优势。视图作为虚拟表,可简化复杂查询并提升代码可维护性;存储过程则预编译 SQL 语句,支持复杂逻辑与事务处理,增强代码复用性和安全性。通过创建视图 `high_earners` 和存储过程 `get_employee_details` 及 `update_salary` 的实例,展示了二者在实际项目中的强大功能。
41 1
下一篇
无影云桌面