代码自动生成工具MyGeneration之一(程序员必备工具)
代码自动生成工具MyGeneration之一(程序员必备工具)
转
分类: C#2008-08-06 18:12 16064人阅读 评论(12) 收藏 举报
前段时间用C#做网站,用到了大量数据库相关的东西。网站采用3层结构,即数据访问层(Data Access Layer),业务逻辑层(Business Logic Layer),页面表现层().做了一段时间,发现向数据访问层和业务逻辑层加入新的类,数据库的表结构改了,还要对应的修改数据访问层和业务逻辑层的代码,这个工作很是繁琐,无聊,而且容易出错。做了几次之后就想有什么办法可以让机器自动完成呢?
联想到以前看过Java似乎有个Hibernate,可以很方便的实现对象关系映射(ORM),即自动的从数据库的表生成对应的对象,.Net也应该有类似的功能吧。于是找啊找,发现了很多.Net的ORM工具,不过都有缺点,就是代码得依赖于那些ORM工具,我希望能够让机器按我的要求生成我自己的代码,这样就更加灵活了。
于是乎,发现了CodeSmith和MyGeneration,CodeSmith是 网上传的.NET 程序员十种必备工具之一,我们写代码时,经常需要重复完成某些特定的任务,例如编写数据访问代码或者生成自定义集合。我们可以用CodeSmith编写模板自动完成这些任务,从而不仅提高工作效率,而且能够自动完成那些最为乏味的任务。可惜,CodeSmith是需要注册的,试用版只能用15天。而MyGeneration基本上和CodeSmith的功能差不多哦,但是他是开源的。我选软件的原则是能开源免费的就用,实在没替代了才选那些需要注册的,有版权的软件。所以就选MyGeneration了。
用过一段时间后感觉MyGeneration主要是为了自动生成数据库相关的代码的,可能C#用得比较多,其实我们可以用它生成任何代码,C++,JavaScript...而且还不仅仅局限于数据库,其他方面的代码也可以用MyGeneration自动生成。比如我们经常用数据访问层和业务逻辑层,用MyGeneration就可以自动生成这些代码,我们可以不用手动写代码了。比如数据访问层,我们需要调用一个存储过程,用MyGeneration我们只需要选择生成存储过程代码的模板,执行一下脚本,然后在界面上选择数据库上某个存储过程,然后就自动生成了数据库访问代码,整个过程只需要点几下鼠标,代码就自动生成了。这对于需要大量操作数据库的程序员来说,效率是多大的提升啊。
废话少说,还是来点实在的吧。首先声明,我的MyGeneration版本是:1.3.0.3
安装完MyGeneration后,第一次启动会要求进行一些数据库相关的配置。如图:
ConnectionString: 就是指定连接哪个数据库了,填好这个就可以点确定了。
下面来看一看其他的项都是什么。
Language Mapping:就是指定数据库和对象基本类型的映射关系。让我们打开Languages.xml文件看一下吧:
- <Language From="SQL" To="C#">
- <Type From="bigint" To="long" />
- <Type From="binary" To="object" />
- <Type From="bit" To="bool" />
- <Type From="char" To="string" />
- <Type From="datetime" To="DateTime" />
- <Type From="decimal" To="decimal" />
- <Type From="float" To="double" />
- <Type From="image" To="byte[]" />
- <Type From="int" To="int" />
- <Type From="money" To="decimal" />
- <Type From="nchar" To="string" />
- <Type From="ntext" To="string" />
- <Type From="numeric" To="decimal" />
- <Type From="nvarchar" To="string" />
- <Type From="real" To="float" />
- <Type From="smalldatetime" To="DateTime" />
- <Type From="smallint" To="short" />
- <Type From="smallmoney" To="decimal" />
- <Type From="text" To="string" />
- <Type From="timestamp" To="byte[]" />
- <Type From="tinyint" To="byte" />
- <Type From="uniqueidentifier" To="Guid" />
- <Type From="varbinary" To="byte[]" />
- <Type From="varchar" To="string" />
- <Type From="xml" To="string" />
- <Type From="sql_variant" To="object" />
- </Language>
这是里面的一段内容,很明显,是数据库SQL的字段转到C#是什么类型,里面没有C++的,假如我们要让它支持C++的话,需要在这里加入SQL到C++的类型转换。
Database Target Mapping:先看里面的内容吧:
- <DbTarget From="ACCESS" To="DAO">
- <Type From="Text" To="DAO.dbText" />
- <Type From="Memo" To="DAO.dbMemo" />
- <Type From="DateTime" To="DAO.dbDate" />
- <Type From="Currency" To="DAO.dbCurrency" />
- <Type From="Yes/No" To="DAO.dbBoolean" />
- <Type From="OLE Object" To="DAO.dbLongBinary" />
- <Type From="Hyperlink" To="DAO.dbMemo" />
- <Type From="Double" To="DAO.dbDouble" />
- <Type From="Replication ID" To="DAO.dbGUID" />
- <Type From="Long" To="DAO.dbLong" />
- <Type From="Single" To="DAO.dbSingle" />
- <Type From="Decimal" To="DAO.dbDecimal" />
- <Type From="Byte" To="DAO.dbByte" />
- <Type From="Integer" To="DAO.dbInteger" />
- </DbTarget>
呵呵,一目了然,就是Access数据库用DAO的方式访问,数据库的列的类型对应的DAO里是什么类型。
UseMetaData目前没什么用。
看看MyGeneration的界面吧:
Template Browser 面板 列出了一些模板,这是自动生成代码需要用到的模板。安装的时候会自己带很多模板。
MyMeta Browser则列出了当前连接的数据库上有些什么库,表,存储过程。
工作区则是具体模板对应的代码。
先让我们体验一下吧。
展开Template Browser面板下"d00dads - C#", 双击 “d00dads - Invoke a Stored Procedure", 让工作区显示其内容,
然后点击工具栏上的 "Execute" 按钮,如图红框所示:
弹出对话框,如图:
选择数据库,存储过程,存储过程类型,点确定(OK)。
然后可以看到工作区 Output 里输出了代码了。例如:
- using System.Data;
- using System.Collections.Specialized;
- using System.Data.SqlClient;
- public virtual void dm_exec_cursors (int spid)
- {
- ListDictionary parameters = new ListDictionary();
- parameters.Add( new SqlParameter("@spid", SqlDbType.Int, 0), spid);
- LoadFromSqlNoExec("dm_exec_cursors", parameters);
- }
这就是MyGeneration自动获取了存储过程的输入参数,然后在代码里构造相应的参数,然后生成的代码。
这只是MyGeneration自带的模板生成的,大家可以试一试其他的模板的效果。
里面有自动根据表结构生成BLL的类......看下效果:
- /*
- '===============================================================================
- ' Generated From - CSharp_dOOdads_BusinessEntity.vbgen
- '
- ' ** IMPORTANT **
- ' How to Generate your stored procedures:
- '
- ' SQL = SQL_StoredProcs.vbgen
- ' ACCESS = Access_StoredProcs.vbgen
- ' ORACLE = Oracle_StoredProcs.vbgen
- ' FIREBIRD = FirebirdStoredProcs.vbgen
- ' POSTGRESQL = PostgreSQL_StoredProcs.vbgen
- '
- ' The supporting base class OleDbEntity is in the Architecture directory in "dOOdads".
- '
- ' This object is 'abstract' which means you need to inherit from it to be able
- ' to instantiate it. This is very easilly done. You can override properties and
- ' methods in your derived class, this allows you to regenerate this class at any
- ' time and not worry about overwriting custom code.
- '
- ' NEVER EDIT THIS FILE.
- '
- ' public class YourObject : _YourObject
- ' {
- '
- ' }
- '
- '===============================================================================
- */
- // Generated by MyGeneration Version # (1.3.0.3)
- using System;
- using System.Data;
- using System.Data.OleDb;
- using System.Collections;
- using System.Collections.Specialized;
- using MyGeneration.dOOdads;
- namespace Your.Namespace
- {
- public abstract class _Users : OleDbEntity
- {
- public _Users()
- {
- this.QuerySource = "Users";
- this.MappingName = "Users";
- }
- //=================================================================
- // public Overrides void AddNew()
- //=================================================================
- //
- //=================================================================
- public override void AddNew()
- {
- base.AddNew();
- }
- public override string GetAutoKeyColumn()
- {
- return "ID";
- }
- public override void FlushData()
- {
- this._whereClause = null;
- this._aggregateClause = null;
- base.FlushData();
- }
- //=================================================================
- // public Function LoadAll() As Boolean
- //=================================================================
- // Loads all of the records in the database, and sets the currentRow to the first row
- //=================================================================
- public bool LoadAll()
- {
- ListDictionary parameters = null;
- return base.LoadFromSql("[" + this.SchemaStoredProcedure + "proc_UsersLoadAll]", parameters);
- }
- //=================================================================
- // public Overridable Function LoadByPrimaryKey() As Boolean
- //=================================================================
- // Loads a single row of via the primary key
- //=================================================================
- public virtual bool LoadByPrimaryKey()
- {
- ListDictionary parameters = new ListDictionary();
- return base.LoadFromSql("[" + this.SchemaStoredProcedure + "proc_UsersLoadByPrimaryKey]", parameters);
- }
- #region Parameters
- protected class Parameters
- {
- public static OleDbParameter ID
- {
- get
- {
- return new OleDbParameter("@ID", OleDbType.Integer, 0);
- }
- }
- public static OleDbParameter Alias
- {
- get
- {
- return new OleDbParameter("@Alias", OleDbType.VarChar, 2147483647);
- }
- }
- }
- #endregion
- #region ColumnNames
- public class ColumnNames
- {
- public const string ID = "ID";
- public const string Alias = "Alias";
- static public string ToPropertyName(string columnName)
- {
- if(ht == null)
- {
- ht = new Hashtable();
- ht[ID] = _Users.PropertyNames.ID;
- ht[Alias] = _Users.PropertyNames.Alias;
- }
- return (string)ht[columnName];
- }
- static private Hashtable ht = null;
- }
- #endregion
- #region PropertyNames
- public class PropertyNames
- {
- public const string ID = "ID";
- public const string Alias = "Alias";
- static public string ToColumnName(string propertyName)
- {
- if(ht == null)
- {
- ht = new Hashtable();
- ht[ID] = _Users.ColumnNames.ID;
- ht[Alias] = _Users.ColumnNames.Alias;
- }
- return (string)ht[propertyName];
- }
- static private Hashtable ht = null;
- }
- #endregion
- #region StringPropertyNames
- public class StringPropertyNames
- {
- public const string ID = "s_ID";
- public const string Alias = "s_Alias";
- }
- #endregion
- #region Properties
- public virtual Integer ID
- {
- get
- {
- return base.GetInteger(ColumnNames.ID);
- }
- set
- {
- base.SetInteger(ColumnNames.ID, value);
- }
- }
- public virtual String Alias
- {
- get
- {
- return base.GetString(ColumnNames.Alias);
- }
- set
- {
- base.SetString(ColumnNames.Alias, value);
- }
- }
- #endregion
- #region String Properties
- public virtual string s_ID
- {
- get
- {
- return this.IsColumnNull(ColumnNames.ID) ? string.Empty : base.GetIntegerAsString(ColumnNames.ID);
- }
- set
- {
- if(string.Empty == value)
- this.SetColumnNull(ColumnNames.ID);
- else
- this.ID = base.SetIntegerAsString(ColumnNames.ID, value);
- }
- }
- public virtual string s_Alias
- {
- get
- {
- return this.IsColumnNull(ColumnNames.Alias) ? string.Empty : base.GetStringAsString(ColumnNames.Alias);
- }
- set
- {
- if(string.Empty == value)
- this.SetColumnNull(ColumnNames.Alias);
- else
- this.Alias = base.SetStringAsString(ColumnNames.Alias, value);
- }
- }
- #endregion
- private AggregateClause _aggregateClause = null;
- #endregion
- protected override IDbCommand GetInsertCommand()
- {
- OleDbCommand cmd = new OleDbCommand();
- cmd.CommandType = CommandType.StoredProcedure;
- cmd.CommandText = "[" + this.SchemaStoredProcedure + "proc_UsersInsert]";
- CreateParameters(cmd);
- return cmd;
- }
- protected override IDbCommand GetUpdateCommand()
- {
- OleDbCommand cmd = new OleDbCommand();
- cmd.CommandType = CommandType.StoredProcedure;
- cmd.CommandText = "[" + this.SchemaStoredProcedure + "proc_UsersUpdate]";
- CreateParameters(cmd);
- return cmd;
- }
- protected override IDbCommand GetDeleteCommand()
- {
- OleDbCommand cmd = new OleDbCommand();
- cmd.CommandType = CommandType.StoredProcedure;
- cmd.CommandText = "[" + this.SchemaStoredProcedure + "proc_UsersDelete]";
- OleDbParameter p;
- return cmd;
- }
- private IDbCommand CreateParameters(OleDbCommand cmd)
- {
- OleDbParameter p;
- p = cmd.Parameters.Add(Parameters.ID);
- p.SourceColumn = ColumnNames.ID;
- p.SourceVersion = DataRowVersion.Current;
- p = cmd.Parameters.Add(Parameters.Alias);
- p.SourceColumn = ColumnNames.Alias;
- p.SourceVersion = DataRowVersion.Current;
- return cmd;
- }
- }
- }
这就是自动获得表结构,然后从字段映射成类里面的成员,并且还有一些插入,更新,删除的代码。
当然自带的模板生成的代码不一定符合我们的需要,但是我们可以根据需要自己写一些模板来生成符合自己需要的代码,这也是非常容易的事,欲知如何实现,请看下回文章。
代码自动生成工具MyGeneration之一(程序员必备工具)的更多相关文章
- 十大PHP程序员必备工具
十大PHP程序员必备工具 1.Notepad++ 总结来说就是小而精,7.4版本的软件包只有2.9M,比一般的IDE小数十倍,但是Notepad++的功能确是很全面的,代码高亮,语法折叠,宏功能,内置 ...
- 基于eclipse的mybatis映射代码自动生成的插件
基于eclipse的mybatis映射代码自动生成的插件 分类: JAVA 数据库 工具相关2012-04-29 00:15 2157人阅读 评论(9) 收藏 举报 eclipsegeneratori ...
- 基于eclipse的mybatis映射代码自动生成的插件http://blog.csdn.net/fu9958/article/details/7521681
基于eclipse的mybatis映射代码自动生成的插件 分类: JAVA 数据库 工具相关2012-04-29 00:15 2157人阅读 评论(9) 收藏 举报 eclipsegeneratori ...
- 基于数据库的代码自动生成工具,生成JavaBean、生成数据库文档、生成前后端代码等(v6.0.0版)
TableGo v6.0.0 版震撼发布,此次版本更新如下: 1.UI界面大改版,组件大调整,提升界面功能的可扩展性. 2.新增BeautyEye主题,界面更加清新美观,也可以通过配置切换到原生Jav ...
- Asp.net mvc 5 CRUD代码自动生成工具- vs.net 2013 Saffolding功能扩展
Asp.net mvc 5 CRUD代码自动生成工具 -Visual Studio.net2013 Saffolding功能扩展 上次做过一个<Asp.net webform scaffoldi ...
- C# 代码自动生成工具
开源:C# 代码自动生成工具,支持站点前后台 前言 写这个项目有很长一段时间了,期间也修修改改,写到最后,自己也没咋用(研究方向变化了). 正文 具体项目开源了:https://github.co ...
- iBatis 代码自动生成工具 iBator 及 Example 使用
iBator的下载和安装 官方下载地址:http://people.apache.org/builds/ibatis/ibator/ 安装:见<Eclipse 插件安装> 安装完成后,“F ...
- 代码自动生成工具_java版
项目结构: 这里要实现的功能是,当我们给出了bean,如:Admin,User,People等实体类后, 我想用代码自动生成我想要的代码,最后生成的效果: 也就是说为每一个bean都生成相应的Dao, ...
- Java程序员必备的 15框开发工具
15款Java程序员必备的开发工具 如果你是一名Web开发人员,那么用膝盖想也知道你的职业生涯大部分将使用Java而度过.这是一款商业级的编程语言,我们没有办法不接触它. 对于Java,有两种截然不同 ...
随机推荐
- MAC OS Nginx php-fpm相关
Nginx 命令 sudo nginx // 启动Nginx #重新加载|重启|停止|退出 sudo nginx -s reload|reopen|stop|quit #上传文件限制更改: 进入ngi ...
- CodeForces114E——Double Happiness(素数二次筛选)
Double Happiness On the math lesson a teacher asked each pupil to come up with his own lucky numbers ...
- POJ2965——The Pilots Brothers' refrigerator
The Pilots Brothers' refrigerator Description The game “The Pilots Brothers: following the stripy el ...
- JS中的自执行函数
本来规划的是2013年,狠狠的将JS学习下,谁知计划赶不上变化,计划泡汤了.13年的我对JS来说可以说是属于跟风,对它的理解和认识也仅仅是皮毛而已,也是因为要完成<ArcGIS API for ...
- 将OutLook.exe注册为服务,让其一直保持开启状态
类似于TaobaoProtect.exe是由TBSecSvc服务启动的 http://stackoverflow.com/questions/3582108/create-windows-servic ...
- Playing with cubes II
Description: Hey Codewarrior! You already implemented a Cube class, but now we need your help again! ...
- Ubuntu安装node.js
通过PPA安装Node.js sudo apt-get install python-software-properties sudo add-apt-repository ppa:chris-lea ...
- CodeForces 135 B. Rectangle and Square(判断正方形和 矩形)
题目:http://codeforces.com/problemset/problem/135/B 题意:给8个点 判断能否用 4个点构成正方形,另外4个点构成 矩形. 输出 第一行是正方形 ,第二行 ...
- bzoj1607: [Usaco2008 Dec]Patting Heads 轻拍牛头
筛法. 枚举每个数,它会对它的倍数的答案有贡献. 数大了以后,倍数相应少了很多.比枚举每个数的约数要好的多. 自己yy了一种分步做法.小于sqrt(m)被当作约数枚举,大于sqrt(m)的枚举倍数. ...
- WordPress 3.8.1 /xmlrpc.php拒绝服务漏洞
漏洞版本: WordPress 3.8.1 漏洞描述: WordPress是一款内容管理系统. WordPress 3.8.1 /xmlrpc.php 文件有ping其他主机的功能,通过这个功能可以请 ...