大家都知道,在CodeSmith中现在没有提供选择字段的功能,我们在生成一个List页面时,不可能对整张表的所有字段都生成,所以有必要去实现选择字段的功能。我在网上搜集了一下,大体上有以下几种实现思路:
1. 使用TableSchema和TableSchemaCollection来代替。在一张数据表中保存所有的字段并设置一个标识,在模版中通过访问这些标识来控制我们的输出,实现起来比较简单,但是这样代码生成需要借助于外部工具来实现。这个外部工具可以是我们自己编写的一个小工具,对要生成的字段进行标识的设置即可。
2. 如果我们使用的是SQL Server数据库,可以在列上面设置扩展属性,然后在模版中使用这些扩展属性来控制输出。SQL Server提供了一个存储过程sp_addextendedproperty来为数据库中的对象添加扩展属性,这种方法实现起来很麻烦,需要对数据库中所有用到的对象添加扩展属性,虽然也可以写一个小工具来实现,但是那就又是借助于外部工具了。关于扩展属性的使用请参见CodeSmith实用技巧(四):使用扩展属性
3. 在选择表时仍然使用TableSchema,并使用一个自定义属性的StringCollection对话框去掉某些字段或表。在生成代码中,我们需要生成的字段就是SourceTable.Columns中除去StringCollection List中的那部分字段。实现起来比较简单,缺点是需要手工输入字段或表的名称。在CodeSmith提供的模版例子程序中也是采用了这种实现方式。关于StringCollection的具体使用参见CodeSmith实用技巧(一):使用StringCollection
4. 最后一种就是使用设计器的支持,也是最理想的一种想法,就是通过自定义属性对话框来根据自己的需要编写窗体,需要继承于UITypeEditor类。这样在这个窗体中我们可以通过SQLDMO来获取数据库中对象的信息,提供一个友好的选择字段界面。这种方式的优点就不用说了,缺点是编写窗体比较复杂,实现起来有一定的难度。关于设计器的支持请参见CodeSmith实用技巧(十一):添加设计器的支持