MyGeneration学习笔记(1) : 使用MyGeneration生成存储过程和数据访问层代码

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云原生数据库 PolarDB MySQL 版,通用型 2核4GB 50GB
简介:

      MyGenertion是一款不错的代码生成ORM代码生成工具,下面是我学习过程中的一些笔记(总结了一下dOOdads C# Quick Reference文档,还有自己在使用和调试过程中遇到的问题及自己的解决方法),贴出来与大家共享 。

 

     这篇文章主要讲解怎样用MyGeneration(我用的MyGeneration的版本号是1.5.1)的dOOdad模板(使用其自带的模版)来生成代码,及将这些代码加入到项目中。

  

1.   准备工作: 数据库设计(MS Sql Server):
   1). 为每张表设置一个identity列作为主键。也可以用GUID或多列作为主键。
   2). 为每张表增加列名为“RowVersion”的列,数据类型设为时间戳(timestamp)。dOOdad将用这列处理并发。
   3). dOOdad只能处理单张表,不能处理多表联合查询。要处理多张表,可以创建视图,用操作试图替换多表问题。
   4). 在设计数据库和应用程序时,尽可能少地使用null。

  

2.  安装MyGeneration,添加dOOdad项目到解决方案:
   1). 从http://www.mygenerationsoftware.com下载并安装。


   2). 安装完成后,dOOdad项目位于..\MyGeneration\Architectures\dOOdad\CSharp\MyGeneration.dOOdad\目录下,有两个版本,2003和2005,根据你的需求,选择一个添加到解决方案中。另外,目录下有个readme.txt文件,也将了一些dOOdas的使用步骤和说明。
       当然,我们也可以直接打开该项目,编译生成dll文件,然后在应用程序中添加该程序集引用;但该项目的代码还存在一些问题,可能要在调试的时候才能发现,这时再修改代码添加引用就很不方便,所以个人不推荐这样做。
在DbAdapters文件夹下,默认所有的文件的生成操作属性都是"无",即不编译进项目。分别选择应用程序的数据库所对应的两个*Entity.cs和*DynamicQuery.cs两个文件,将他们的属性--生成操作改为"编译",这样就可以编译进生成的Assembly中。
MyGeneration支持的数据库对应的文件:
   SQL Server (SqlClientDynamicQuery.cs, SqlClientEntity.cs)                System.Data.SqlClient
   Access        (OleDbDynamicQuery.cs, OleDbEntity.cs)                          System.Data.OleDb
   Oracle          (OracleClientDynamicQuery.cs, OracleClientEntity.cs)   System.Data.OracleClient
   PostgreSql  (PostgreSqlDynamicQuery.cs, PostgreSqlEntity.cs)       Npgsql   
   Firebird        (FirebirdSqlDynamicQuery.cs, FirebirdSqlEntity.cs)        FirebirdSql.Data.Firebird
   VistaDB       (VistaDBDynamicQuery.cs, VistaDBEntity.cs)                   VistaDB
   SQLite         (SQLiteDynamicQuery.cs, SQLiteEntity.cs)                        Finisar.SQLite
   MySQL         (MySQL4DynamicQuery.cs, MySQL4Entity.cs)                  MySql.Data.MySqlClient
  3). 现在就可以编译了。

 

 

3.  其他需要访问该Assembly的项目:
   1). 为项目添加引用--项目--MyGeneration.dOOdad
   2). 为项目添加两个文件夹:
       DAL(数据访问层):用于存放MyGeneration创建的Abstract类(下面会讲如何使用MyGeneration来生成这些类)。
       BLL(业务逻辑层): 用于存继承上面的Abstract类的具体类,可由MyGeneration自动生成。

 

 

4.  使用MyGeneration:
  4.1 生成CRUD存储过程:
      1) 运行MyGeneration,Edit--DefaultSetting,设置数据库、编程语言等。
      2) 点击工具栏-Template Browser,选择要创建的存储过程的模板
          可用的模版有:
           Microsoft SQL      - Microsoft SQL Server.dOOdad Stored Procedures
           Microsoft Access   - Microsoft Access.Access Stored Procedures
           Oracle             - Oracle.Oracle Stored Procedures
           PostgreSQL         - PostgreSQL.PostgreSQL Stored Procedures
           Firebird           - Firebird.StoredProcedures.Firebird Stored Procedures
      3) 运行模版,选择数据库和表(一般选则所有表),单击确定后,会在OutPut中输出存储过程
      4) 将生成的存储过程拷贝到查询分析器中,然后执行向数据库中写入存储过程。

  4.2 为数据库中的表生成DAL Abstract类:
      同上,选择Template Browser--dOOdad--C#(其他的与此类似)--dOOdad Business Entity--执行模版--选择上面创建的DAL文件夹,设置要生成的类的命名空间和数据库,选择所有表,然后生成Abstract类。


  4.3 为数据库中的视图生成具体类:
      选择dOOdad Business View模版,并将生成的类保存在BLL文件夹,其他同上。


  4.4 生成具体类(也可以自己写):
      选择dOOdad Concrete Class模版,其他同上。

  

5.   Visual Studio中使用上面生成的资源:
    1) 在配置文件web.config或app.config配置连接字符串。dOOdad项目中默认的key是"dbConnection",也可以修改BusinessEntity类中的_defaultConfig字段的值来修改key的默认值。
      另外,dOOdad项目有个问题就是连接字符串并没有初始化(可能是模版的bug),代码如下: 

internal   string  _raw  =   "" ;
virtual   public   string  ConnectionString
{
    
get
    
{
     
return _raw;
    }

   
set
   
{
    _raw 
= value;
   }

}

       虽然可以在应用程序中手动给属性ConnectionString赋值,但这样的话,每个业务实体在new完之后,都要给ConnectionString赋值,比较繁琐不好维护;一个比较好的办法就是在BusinessEntity的构造函数中对_raw进行初始化(自己写代码)。我用的是VS2005,可以用VS2005自动生成配置文件和配置文件的读取类Settings,然后初始化连接字符串,例如:internal string _raw = ProjectName.Properties.Settings.Default.ConnectionString;

   2)  可以在上面生成的具体类(Concrete Class)中添加应用程序自己的业务逻辑,可处理自定义存储过程和SQL语句等。


本文转自Silent Void博客园博客,原文链接:http://www.cnblogs.com/happyhippy/archive/2006/08/23/601241.html,如需转载请自行联系原作者

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4月前
|
存储 关系型数据库 MySQL
MySQL数据库——存储过程-条件处理程序(通过SQLSTATE指定具体的状态码,通过SQLSTATE的代码简写方式 NOT FOUND)
MySQL数据库——存储过程-条件处理程序(通过SQLSTATE指定具体的状态码,通过SQLSTATE的代码简写方式 NOT FOUND)
34 0
MySQL数据库——存储过程-条件处理程序(通过SQLSTATE指定具体的状态码,通过SQLSTATE的代码简写方式 NOT FOUND)
|
4月前
|
SQL 存储 关系型数据库
MySQL存储过程——Baidu Comate智能代码助手添加20条DML语句——测试索引效果
MySQL存储过程——Baidu Comate智能代码助手添加20条DML语句——测试索引效果
29 0
|
存储 SQL 关系型数据库
SQL 存储过程 procedure 讲解+代码实例
SQL 存储过程 procedure 讲解+代码实例
SQL 存储过程 procedure 讲解+代码实例
|
存储 SQL 关系型数据库
MySQL 之存储过程|学习笔记
快速学习 MySQL 之存储过程
MySQL 之存储过程|学习笔记
|
存储 SQL 安全
SQL 存储过程和函数的对比、变量、条件和处理程序、游标、流程控制详解+代码示例
SQL 存储过程和函数的对比、变量、条件和处理程序、游标、流程控制详解+代码示例
|
存储 SQL NoSQL
MySQL学习笔记 05、触发器、存储过程、存储函数、定时任务(二)
MySQL学习笔记 05、触发器、存储过程、存储函数、定时任务(二)
MySQL学习笔记 05、触发器、存储过程、存储函数、定时任务(二)
|
存储 SQL 关系型数据库
MySQL学习笔记 05、触发器、存储过程、存储函数、定时任务(一)
MySQL学习笔记 05、触发器、存储过程、存储函数、定时任务(一)
MySQL学习笔记 05、触发器、存储过程、存储函数、定时任务(一)
|
存储 SQL Java
Mybatis学习笔记(四)调用存储过程
Mybatis学习笔记(四)调用存储过程
|
SQL 存储 Oracle
Oracle数据库学习笔记四——存储过程的值传递和引用传递
Oracle数据库学习笔记四——存储过程的值传递和引用传递
296 0
|
存储 SQL 安全
MySQL存储过程学习笔记
存储过程时数据库的一个重要的对象,可以封装SQL语句集,可以用来完成一些较复杂的业务逻辑,并且可以入参出参(类似于java中的方法的书写)。
165 0