数据字典生成工具之旅(7):NVelocity实现代码生成器

      这个系统好久没有更新了,人也慢慢变懒了,从现在开始每个月至少写三篇文章,欢迎大家监督。对了预告一下,该系列完成以后将为大家带来WebApp开发系列篇,敬请期待。先上几张图,放在文章最后面欢迎预览!

     本章开始将会为大家讲解NVelocity的用法,并带领大家实现一个简单的代码生成器。

  NVelocity的基础知识请参考上篇文章NVelocity语法介绍

阅读目录

回到顶部

NVelocity实现代码生成器

    实现一款简单的代码生成器,需要先定义好代码结构。这里仅生成三层模式中的实体层,后续复杂结构代码生成大家可以自己动手写一下。

   1、 模版定义

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace Mysoft.Code.Entity
{
    #foreach($p in $T.Rows)##
         #if($velocityCount==1)##
         ///<summary>$p.get_item("table_name_c")</summary>
         public class  $p.get_item("table_name")
        {
        #end
       
       ///<summary>#if($p.get_item("field_name_c")!="")$p.get_item("field_name_c") #else $p.get_item("field_name") #end</summary>
       public#if($p.get_item("date_type")=="bigint") double#else string#end $p.get_item("field_name")
       {
	   get;
	   set;
        }
    #end
   }   
}

   可以看到模版很简单,最终生成的代码类似下面

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace Mysoft.Code.Entity
{
        ///<summary>阶段设置表</summary>
    public class  Pack_Stage
    {
           
       ///<summary>更新包GUID </summary>
       public string StageGUID
       {
            get;
            set;
       }
                  
       ///<summary>更新包名称 </summary>
       public string StageName
       {
            get;
            set;
       }
                  
       ///<summary>阶段序号 </summary>
       public string OrderNo
       {
            get;
            set;
       }
                  
       ///<summary>是否开始合并包 </summary>
       public string IsHBPackage
       {
            get;
            set;
       }
       }   
}

2、从数据库中读取所有表和表的相关信息     SQL Sever的内置表和视图提供了许多有用信息,比如查询所有的用户表和表列信息说明。

    sys.tables:用户表相关信息

    sys.extended_properties:表的和列的相关描述信息

 SELECT  T.name AS table_name ,T.OBJECT_ID,
        ISNULL(CONVERT(VARCHAR(MAX), E.value), '') AS table_name_c ,
        C.name AS field_name ,
        ISNULL(CONVERT(VARCHAR(MAX), D.value), '') AS field_name_c ,
        ROW_NUMBER() OVER(PARTITION BY T.name ORDER BY C.colid) AS field_sequence ,
        TYPE_NAME(C.xtype) AS date_type ,
        (CASE WHEN EXISTS ( SELECT   1
                           FROM     sysobjects
                           WHERE    xtype = 'PK'
                                    AND name IN (
                                    SELECT  name
                                    FROM    sysindexes
                                    WHERE   id = C.id
                                            AND indid IN (
                                            SELECT  indid
                                            FROM    sysindexkeys
                                            WHERE   id = C.id
                                                    AND colid = C.colid ) ) )
             THEN 1
             ELSE 0
        END) AS pk ,
        ISNULL(C.isnullable, 1) AS isnullable ,
        ISNULL(COLUMNPROPERTY(c.id, c.name, 'IsIdentity'), 0) AS isidentity
FROM   sys.tables AS T
        LEFT JOIN syscolumns AS C ON c.id = T.object_id
        LEFT JOIN sys.extended_properties AS D ON D.major_id = T.object_id
                                                  AND D.minor_id = C.colid
                                                  AND D.major_id = C.id
        LEFT JOIN sys.extended_properties AS E ON E.major_id = T.object_id
                                                  AND E.minor_id = 0

   大家可以看下上面的SQL,基本上把表的相关信息都查询出来了,下章将着重讲解这个知识点。

 3、代码生成

有了模版和数据源就可以生成最终代码了,有不懂的可以参考上篇,这里上最终效果图。大家可以下载示例代码自行查看。

本章例子下载

回到顶部

本章总结

     整个代码生成器做起来还是不困难的,前台界面搭建用到了最近比较流行的miniui,有兴趣的自己可以下载研究。实例中代码文件输出路径和数据库链接配置在了Web.Config中使用者可自行修改。

  另外开发过程中遇到的几个问题也分享一下:

     1.NVelocity中如何使用DataTable做为数据源

       #foreach($p in $T.Rows)

          ($p.get_item("date_type")        #end

     2.DataTable进行数据过滤

              DataView dv = dt.DefaultView;               dv.RowFilter = "tableid='" + id + "'";               DataTable dt2 = dv.ToTable();

   好了本章内容就这么多了,希望读完对你有所帮助!

回到顶部

新系列文章图片预览

回到顶部

工具源代码下载

      目前总共有经过了七个版本的升级,现在提供最新版本的下载地址

数据字典生成工具V2.0安装程序

最新安装程序

数据字典生成工具源代码

最新源代码

http://code.taobao.org/svn/DataDicPub

SVN最新源码共享地址

回到顶部

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏JMCui

记录一次批量插入的优化历程

1272
来自专栏杨建荣的学习笔记

物化视图prebuilt和在线重定义 (r10笔记第25天)

数据迁移中有一种解决方案很有亮点,如果表的数据量大,迁移涉及的表不多,同时对于维护时间有要求的情况下,物化视图的prebuilt方式就是一种很不错的选择。 大体...

3414
来自专栏java系列博客

pl/sql导入excel到oracle表

2097
来自专栏linux驱动个人学习

耳机驱动程序上报

1222
来自专栏数据和云

时过境迁:Oracle跨平台迁移之XTTS方案与实践

作者简介 ? 谢金融 云和恩墨东区交付部 Oracle 工程师,多年来从事 Oracle 第三方服务,曾服务过金融、制造业、物流、政府等许多行业的客户,精通数据...

57110
来自专栏大数据

Python 101:如何从RottenTomatoes爬取数据

今天,我们将研究如何从热门电影网站Rotten Tomatoes爬取数据。你需要在这里注册一个API key。当你拿到key时,记下你的使用限制(如每分钟限制的...

4436
来自专栏沃趣科技

mysqldump与innobackupex备份过程你知多少(二)

1.2.3. 使用WITH CONSISTENT SNAPSHOT子句的作用 START TRANSACTION语句使用WITH CONSISTENT SNA...

3766
来自专栏数据和云

【合理授权,安全第一】聊一聊Oracle数据库的用户权限

编辑手记:年底大家最关注数据安全,之前我们说过,数据库的风险分为外部风险和内部风险。外部风险无法预估但概率较小,平时发生最多的还是内部操作的风险,因此合理控制权...

2615
来自专栏散尽浮华

Mysql读写分离方案-MySQL Proxy环境部署记录

Mysql的读写分离可以使用MySQL Proxy和Amoeba实现,其实也可以使用MySQL-MMM实现读写分离的自动切换。MySQL Proxy有一项强大功...

3288
来自专栏PingCAP的专栏

TiDB 2.1 GA Release Notes

2018 年 11 月 30 日,TiDB 发布 2.1 GA 版。相比 2.0 版本,该版本对系统稳定性、性能、兼容性、易用性做了大量改进。

780

扫码关注云+社区