NHibernate + SQLite + MVC 开发记录

NHibernate + SQLite + MVC 开发记录

ID:37467529

大小:1.51 MB

页数:26页

时间:2019-05-24

NHibernate + SQLite + MVC 开发记录_第1页
NHibernate + SQLite + MVC 开发记录_第2页
NHibernate + SQLite + MVC 开发记录_第3页
NHibernate + SQLite + MVC 开发记录_第4页
NHibernate + SQLite + MVC 开发记录_第5页
资源描述:

《NHibernate + SQLite + MVC 开发记录》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、NHibernate+SQLite+MVC开发记录马上要转向学习Android开发了,打算做一个关于C#的总结项目这是我在后面加上来的图片。我会把实现的步骤一一记录。。所有的文章都是我一边调试一边记录的再加上水平有限所以在开发过程中不可避免会有很多错误,希望大家谅解。好下面让我们开始吧一起解决问题,共同进步。开发环境vs2008+NHibernate+SQLite为了避免一些因为使用的类库组件的版本不同而与大家产生的异常出错等,我公布一下各版本号文件名文件版本NHibernate.dll1.2.1.4000SQLite.NET.dll0.21.1869.3794Cas

2、tle.DynamicProxy.dll1.1.5.0Iesi.Collections.dll1.2.1.4000log4net.dll1.2.10.0sqlite3.dll3.5.7其中log4net.dll可以不要,sqlite3.dll版本号可以不同没有问题。26/26然后打开VS来建立项目,我是模仿人人网旗下的一款网页游戏《乱世天下》来写的一个WinForm的单机游戏。项目建立完成后如下图所示其中UI为Windows窗体应用程序,其它均为类库.第一节先到这里下一节将建立实体类及映射配置Nhibernate,SQLite等。现在建立SQLite的数据库我采用的是

3、一个SQLite可视化的界面开发工具SQLiteExpert,界面如下:新建一个数据库:26/26可以在这里写入SQL这里我只贴出部分代码大家也不太关心这个,值得一提是的:每条语句必须以";"分号结束。select,insertinto...等等都需要分号结束。每张表的主键如果是INTEGER类型的话它会自动地增长而不需要你再去加IDENTITY,但类型必须是INTEGER,int不会自增.建立关系譬如外键FOREIGNKEY,不能像这样:CREATETABLEIFNOTEXISTSo_user(26/26userIDINTEGERPRIMARYKEY,userNam

4、eVARCHAR(18)UNIQUENOTNULL,userPwdVARCHAR(18)NOTNULL,playerIDINTEGERFOREIGNKEYREFERENCESo_player(playerID));会提示FOREIGNKEY错误,要像这样写:CREATETABLEIFNOTEXISTSo_user(userIDINTEGERPRIMARYKEY,userNameVARCHAR(18)UNIQUENOTNULL,userPwdVARCHAR(18)NOTNULL,playerIDINTEGER,FOREIGNKEY(playerID)REFERENCES

5、o_player(playerID));关于外键还有一点要说,SQLite默认foreign_keys是关闭的,你可以用触发器或者手动设置PRAGMAforeign_keys=ON。接下来我们F5执行这段SQL语句,得到还有很多表目前没有设计完,但不影响前期的开发,我打算后面再去加入它们。然后我们就要去建立实体类和配置文件了,你可以用工具自动生成实体类以及映射文件,譬如说MyGeneration,很久以前就开源了你可以修改或者制作自己喜欢的模板,但初学者就自己手动创建吧,这样比较容易弄明白各个配置之间的关系,你也就更容易掌握它,调试改错也很快。下一节我们将手动创建这些

6、类和文件。本节建立实体类、映射、关系等26/261:准备类库组件把Castle.DynamicProxy.dllIesi.Collections.dlllog4net.dllNHibernate.dllSQLite.NET.dll拷贝到UI的binDebug下。2:添加引用各项目之间添加引用UI引用BLL,Model;BLL引用DAL,Model;DAL引用Model。对DAL添加Castle.DynamicProxy.dllIesi.Collections.dlllog4net.dllNHibernate.dllSQLite.NET.dll的引用。3:拷贝数据库文

7、件lstx.db和sqlite3.dll到UI项目下,并且在文件属性中,将文件的“复制到输出目录”设置为“如果较新则复制”。准备工作做好了我们在Model里写实体类,我就先挑个简单的User类来写吧。User类在我的数据库中对应o_user表,表中有userIDINTEGER,userNameVARCHAR,userPwdVARCHAR,playerIDINT,其中playerID为外键,对应到o_player表中的playerID。类结构如下:[csharp]viewplaincopyprint?1.publicclassUser2.3.{4.5.

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

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

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