zoukankan      html  css  js  c++  java
  • CodeSmith中实现选择表字段的几点想法

    大家都知道,在CodeSmith中现在没有提供选择字段的功能,我们在生成一个List页面时,不可能对整张表的所有字段都生成,所以有必要去实现选择字段的功能。我在网上搜集了一下,大体上有以下几种实现思路:

    1.   使用TableSchemaTableSchemaCollection来代替。在一张数据表中保存所有的字段并设置一个标识,在模版中通过访问这些标识来控制我们的输出,实现起来比较简单,但是这样代码生成需要借助于外部工具来实现。这个外部工具可以是我们自己编写的一个小工具,对要生成的字段进行标识的设置即可。

    2.   如果我们使用的是SQL Server数据库,可以在列上面设置扩展属性,然后在模版中使用这些扩展属性来控制输出。SQL Server提供了一个存储过程sp_addextendedproperty来为数据库中的对象添加扩展属性,这种方法实现起来很麻烦,需要对数据库中所有用到的对象添加扩展属性,虽然也可以写一个小工具来实现,但是那就又是借助于外部工具了。关于扩展属性的使用请参见CodeSmith实用技巧(四):使用扩展属性

    3.   在选择表时仍然使用TableSchema,并使用一个自定义属性的StringCollection对话框去掉某些字段或表。在生成代码中,我们需要生成的字段就是SourceTable.Columns中除去StringCollection List中的那部分字段。实现起来比较简单,缺点是需要手工输入字段或表的名称。在CodeSmith提供的模版例子程序中也是采用了这种实现方式。关于StringCollection的具体使用参见CodeSmith实用技巧(一):使用StringCollection

    4.   最后一种就是使用设计器的支持,也是最理想的一种想法,就是通过自定义属性对话框来根据自己的需要编写窗体,需要继承于UITypeEditor类。这样在这个窗体中我们可以通过SQLDMO来获取数据库中对象的信息,提供一个友好的选择字段界面。这种方式的优点就不用说了,缺点是编写窗体比较复杂,实现起来有一定的难度。关于设计器的支持请参见CodeSmith实用技巧(十一):添加设计器的支持

     

    支持TerryLee的创业产品Worktile
    Worktile,新一代简单好用、体验极致的团队协同、项目管理工具,让你和你的团队随时随地一起工作。完全免费,现在就去了解一下吧。
    https://worktile.com
  • 相关阅读:
    Android学习笔记ActionView
    Android学习笔记添加ActionItem
    Android学习笔记显示和隐藏ActionBar
    Android学习笔记上下文菜单
    Android学习笔记菜单资源文件
    Android学习笔记样式资源文件
    Android学习笔记主题(Theme)资源文件
    Android学习笔记StateListDrawable文件
    Android学习笔记.9.png格式图片
    笔记本外接显示器设置全屏壁纸
  • 原文地址:https://www.cnblogs.com/Terrylee/p/307980.html
Copyright © 2011-2022 走看看