初探mssqlce+codesmith

初探mssqlce+codesmith

ID:9419893

大小:52.00 KB

页数:4页

时间:2018-04-30

初探mssqlce+codesmith_第1页
初探mssqlce+codesmith_第2页
初探mssqlce+codesmith_第3页
初探mssqlce+codesmith_第4页
资源描述:

《初探mssqlce+codesmith》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、初探MSSQLCE+Codesmith>>教育资源库  本文示例源代码或素材下载  原来的程序是使用sqlite这个嵌入式数据库作为Remit(codename)的数据源的,因为NHibernate支持这个,然而有一点不好的是sqlite不支持外键,导致可悲的codesmith不能得到关系,无法生成我喜欢的多对多映射.如果手写就要写映射xml文件以及业务实体类,这可是我这种懒人不喜欢的.况且数据库经常变更,良好的代码生成可以做到数据库与代码的同步.  硬盘坏了也是一种契机,我突然想到了SqlServer还有一个CE版本,现在不止提供ForMobile的,还提供桌面版.这种可爱的嵌入

2、式数据库可比没意思的Access好得多了.这东西虽然没storeproduce(其实有ORM基本没必要用),但是索引啊,表关系啊还是很全面的.微软的东西就是好,造福全懒人嘛..  然而我的数据库原来是Access的,在网上找了半天工具只找到一个SqlToSqlCe的工具.于是用Access的升迁向导升迁到MSSQL,然后在MSSQLServer里面建立表关系.然后用那个工具导入到SQLCE里面.然后又自己编译了一个Codesmith的数据库Schemaprovider(因为以前这个是for4.0的,而我的是5.0).  那个迁移工具貌似有点问题,没有把表关系完全copy过去,自己的

3、SQLMenagementStudio版本可能太低,不能打开3.5的CE数据库.结果用Codesmith就没法生成我要的关系.不爽.想到NHibernate其实对于表关系是不依赖于数据库的,只要有表就可以了,所以想到一个特别二的方法,就是用MSSQL做Codesmith的数据源,生成文件,而程序中则使用迁移后的CE数据库.(其实感觉直接用MSSQLServer也可以,最后发布的时候换CE)  不过最郁闷的事情是在使用NHibernate进行测试的时候,居然提示我某个查询不能执行,而我在VS2008的数据库的查询里面那个查询是可以运行的SELECTthis_.IDasID2_0_,t

4、his_.BookNameasBookName2_0_,this_.LangIDasLangID2_0_FROMdbo.Bookthis_我实在是很无奈啊,找错误NHibernate扔出来的异常的InnerException也看不出什么来,我就自己用ADO写了一个System.Data.SqlServerCe.SqlCeConnectionconn=ne.Data.SqlServerCe.SqlCeConnection(DataSource=E:LoningLoning.Remitdb.sdf);SqlCemandmand=neand(SELECTthis_.IDasID2_0_,

5、this_.BookNameasBookName2_0_,this_.LangIDasLangID2_0_FROMdbo.Bookthis_,conn);conn.Open();  最后这东西提示表名异常,我一检查表名,想起由于是SqlServer生成的,带着个dbo.前缀,发现生成的NHibernate的配置文件<?xmlversion=1.0encoding=utf-8?><hibernate-mappingxmlns=urn:nhibernate-mapping-2.2namespace=Loning.Remit.BusinessObjectsassembl

6、y=Loning.Remit>   <classname=Loning.Remit.BusinessObjects.Book,Loning.Remittable=dbo.Booklazy=true>       <idname=Idcolumn=ID>            <generatorclass=assigned/>       </id>       <propertyname=BookNamecolumn=BookName/>       <many-to-onename=Languagecolu

7、mn=LangIDclass=Language/>       <bagname=n=BookID></key>           <one-to-manyclass=any>       </bag>   </class></hibernate-mapping>  其中存在dbo.,去掉之后正常,于是更改Codesmith的这个模板.把table.FullName改成table.Name

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。