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
出处:http://terrylee.cnblogs.com
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
posted @ 2005-12-30 10:49 TerryLee 阅读(2007) 评论(6)  编辑 收藏 所属分类: CodeSmith

  回复  引用    
#1楼 2005-12-30 12:49 | 工作、生活 [未注册用户]
呵呵,这个我用StringCollection作为模板的一个属性实现。
  回复  引用  查看    
#2楼 [楼主]2005-12-30 12:51 | Terrylee      
@工作、生活

对于选择表字段实现您有什么好的想法吗?

我现在觉得这块比较棘手:)
  回复  引用  查看    
#3楼 2005-12-30 17:48 | 浮游      
我在数据库的注释里面实现
  回复  引用    
#4楼 2006-07-13 13:57 | know [未注册用户]
能不能写一下MyGeneration的系列^_^
  回复  引用  查看    
#5楼 [楼主]2006-07-13 17:57 | TerryLee      
@know

不会写这个了,因为我从来不用MyGeneration,呵呵:-)
  回复  引用  查看    
#6楼 2008-09-10 08:22 | 赵岩      
学习

标题  
姓名  
主页
Email (博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      


相关链接: