• 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
  • 相关阅读:
    安卓自己定义View进阶-Canvas之绘制基本形状
    IOS UIPickView+sqlite 选择中国全部城市案例
    linux的主分区与逻辑分区的关系
    Qt:解析命令行
    Firefox默认英文修改中文
    autofs自动挂载
    telent对端口检测状态分析
    WinRAR5.4
    Centos6.5入侵清理
    Win10激活KMS
  • 原文地址:https://www.cnblogs.com/Terrylee/p/307980.html
Copyright © 2020-2023  润新知