CodeSmith中实现选择表字段的几点想法
2005-12-30 10:49
302 查看
大家都知道,在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实用技巧(十一):添加设计器的支持
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实用技巧(十一):添加设计器的支持
相关文章推荐
- 在水晶报表中实现任意选择指定字段显示(补充)-格线的实现
- 关于在Web应用中实现MDA+Component的几点想法
- 在水晶报表中实现任意选择指定字段显示(Asp.net+c#版)
- 在水晶报表中实现任意选择指定字段显示
- [导入]CodeSmith应用(四):实现选择路径对话框
- 在水晶报表中实现任意选择指定字段显示
- 水晶报表实现选择任意字段打印(VB)
- [转]在水晶报表中实现任意选择指定字段显示
- 在水晶报表中实现任意选择指定字段显示 (vb.net vs2003)
- CodeSmith应用(四):实现选择路径对话框
- CodeSmith应用(四):实现选择路径对话框
- 【个人想法】个人关于数据库字段类型选择的想法
- 在thinkcmf5中实现为各个分类下的文章添加自定义字段的想法
- [转]在水晶报表中实现任意选择指定字段显示
- 在水晶报表中实现任意选择指定字段显示(补充)-格线的实现
- 实现axWebBrowser的另存、查找、复制选择字段、打印功能
- jquery easy ui 简单字段选择搜索实现
- CodeSmith应用(四):实现选择路径对话框
- 在水晶报表中实现任意选择指定字段显示-模板及C#升级版
- [转] 在水晶报表中实现任意选择指定字段显示 (vb.net vs2003) [来自--http://blog.csdn.net/rainbowsoftware/]