使用NHibernate(2)-- 让程序跑起来
1, 创建一个MVC的程序,NHibernateDemo,并用NuGet安装NHibernate。
安装引用后,NuGet会自动安装NHibernate所依赖的类库 Iesi.Collections
2,配置NHibernate。
首先在Web.config的configSections节点下添加如下配置,声明NHibernate的节点:
<section name="hibernate-configuration" type="NHibernate.Cfg.ConfigurationSectionHandler, NHibernate" />
然后,添加数据库连接字符串的配置
<add name="SqlServer" connectionString="server=.;database=NHDemo;uid=sa;pwd=123456" />
最后,在configuration节点下添加NHibernate相关的配置:
<hibernate-configuration xmlns="urn:nhibernate-configuration-2.2"> <session-factory> <property name="dialect">NHibernate.Dialect.MsSql2008Dialect</property> <property name="connection.driver_class">NHibernate.Driver.SqlClientDriver</property> <property name="connection.connection_string_name">SqlServer</property> <property name="connection.provider">NHibernate.Connection.DriverConnectionProvider</property> </session-factory> </hibernate-configuration>
配置说明:
dialect: 指定NHibernate所使用的方言类(全称),所谓方言是指,不同的数据库所使用sql语法不大一样,可以让NHibernate使用某些特定的数据库特性。这些方言类都继承自抽象类Dialect,所有的实现都在源代码的 src\NHibernate\Dialect 下。
connection.driver_class:数据库驱动类,NHibernate使用这个类来和相应的ADO.NET驱动交互。 这些类的实现在NHibernate源代码的 src\NHibernate\Driver目录下。
connection.connection_string_name: 指定要使用的数据库连接字符串名。
connection.provider : 用来管理数据库连接的打开和关闭,这个属性的目的是为了方便扩展对数据库连接的管理,若要扩展的话,实现IConnectionProvider,并修改此处的配置即可。NHibernate提供的默认实现是上面配置的NHibernate.Connection.DriverConnectionProvider。
3,添加实体及映射。
首先,在Model文件夹下添加用户实体类,代码如下:
public User
{
public virtual long Id {get;set;}
public virtual string name {get;set;}
}
注意,nhibernate要求每个属性都必须是virtual类型的。
然后添加映射文件 User.hbm.xml,注意此xml的生成属性需要修改为“嵌入的资源”,否则会出现异常“No persister for ”,因为nhibernate找不到映射文件。
<?xml version="1.0" encoding="utf-8" ?> <hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="NHibernateDemo"> <class name="NHibernateDemo.Model.User, NHibernateDemo" table="NH_User"> <id name="Id" column="Id" type="System.Int64"> <generator class ="native"/> </id> <property name="Name" column="Name" type="System.String" /> </class> </hibernate-mapping>
最后修改Web.config,在hibernate-configuration/session-factory节点下添加如下代码,告诉nhibernate映射文件所在的程序集
<mapping assembly="NHibernateDemo"/>
4, 添加数据库。
添加一个名为NHDemo的数据库,并添加和User实体对应的表。(表明:NH_User;两个字段:Id, Name,其中Id是主键并且自增)
5,在Global中的Application_Start方法的最后添加如下代码:
var configure = new Configuration().Configure();
SessionFactory = configure.BuildSessionFactory();
首先创建一个Configuration实例,然后通过它创建SessionFactory。注意,项目大的话,SessionFactory的创建是很慢的,推荐一个应用中止存在一个SessionFactory就可以了。顾名思义,SessionFactory是用来创建Session的,我们对数据的访问都是通过它创建的Session。(不要和web中的session搞混,名虽一样,但不是一回事儿)
6,添加数据。
创建一个UserController,并添加如下代码,用于创建数据。
编译并访问 .../User/InitData:
这时候数据库中已经插入数据了。
7,查询数据
添加一个 用于查询数据的的Action,代码如下:
访问后:
使用NHibernate(2)-- 让程序跑起来的更多相关文章
- [Fluent NHibernate]第一个程序
目录 写在前面 Fluent Nhibernate简介 基本配置 总结 写在前面 在耗时两月,NHibernate系列出炉这篇文章中,很多园友说了Fluent Nhibernate的东东,也激起我的兴 ...
- 【翻译】首个基于NHibernate的应用程序
首个基于NHibernate的应用程序 Your first NHibernate based application 英文原文地址:http://www.nhforge.org/wikis/how ...
- .Net程序跑在Linux上
.Net越来越拥抱开源了,今天就试了如何让.Net程序跑在Linux上,果然再无人可以阻挡.Net的脚步了. Linux Disibutaion:Open Logic 7.2 1.Install .N ...
- .NetCore微服务Surging新手傻瓜式 入门教程 学习日志---先让程序跑起来(一)
原文:.NetCore微服务Surging新手傻瓜式 入门教程 学习日志---先让程序跑起来(一) 写下此文章只为了记录Surging微服务学习过程,并且分享给广大想学习surging的基友,方便广大 ...
- 8天入门docker系列 —— 第八天 让程序跑在swarm集群上
真正的落地部署都是希望程序跑在集群下,而不是单机版下测测玩玩,所以这篇就来聊一下怎么使用docker swarm进行部署,因为是swarm是docker自带的, 所以部署起来还是非常简单的. 一:前置 ...
- 记一次stm8l程序跑飞
项目使用stm8l051f3做主控,CC2500做数据接收,不发送. 跑飞的现象就是,刚开始能运行,经过一段未知长度的时间,有可能是3分钟,有可能是30分钟,指示灯不再闪烁,中断按键单片机无反应. 接 ...
- RK3288 st7703 mipi屏指令过长,程序跑飞
本文为博主原创文章,转载请注明出处:https://www.cnblogs.com/lialong1st/p/11218433.html CPU:RK3288 系统:Android 5.1 调试 mi ...
- macOS使用ABP.vNext Core开发CMS系统(一) 让程序跑起来
macOS使用ABP.vNext Core开发CMS系统(一) 让程序跑起来--2020年10月5日 国庆假期,陪老婆的同时也不能忘记给自己充充电,这不想搞个CMS系统,考虑自己的时间并不多,所以想找 ...
- [翻译] 5点建议,让iOS程序跑得更快
[文章原地址]http://mobile.tutsplus.com/tutorials/iphone/ios-quick-tip-5-tips-to-increase-app-performanc ...
随机推荐
- redis cluster 使用中出现的问题
问题一 redis.clients.jedis.exceptions.JedisClusterMaxRedirectionsException: Too many Cluster redirectio ...
- mysql 开通远程连接
使用localhost好用,但是改成ip地址后不好用,执行sql语句做如下修改: update user set host = '%' where user = 'root'; flush privi ...
- 团队-Forward-团队一阶段互评
学号:2015035107105得分:4原因:代码不规范,有一些错误,需要我们的帮助. 学号:2015035107109得分:7原因:与队员沟通少,代码衔接有问题. 学号:2015035107113得 ...
- 检查路径是否存在与创建指定路径(mfc)
检查路径是否存在 if (access("D:\\Work\\Encryption\\DES", 0)) 为真,则路径不存在 创建指定路径 system("md D:\\ ...
- [转]快速入门系列--WebAPI--01基础
本文转自:http://www.cnblogs.com/wanliwang01/p/aspnet_webapi_base01.html ASP.NET MVC和WebAPI已经是.NET Web部分的 ...
- TSQL--标示列、GUID 、序列
--1. IDENTIY 列不能为空,不能设默认值,创建后不能使用ALTER TABLE TableName ALTER COLUMN修改,每张表只能有一个自增列--2. 查看当前值:SELECT I ...
- 升级到Sharepoint 2013后页面打开速度慢
这个问题现在有了一些新的发现. 首先,我找到了重现客户那里出现的那个复杂SQL语句的方法.这个现象其实是这样的: 当WebApplication的“List View Threshold” 数量大于 ...
- ubuntu emacs的安装
在终端依次输入这三条命令即可 sudo add-apt-repository ppa:ubuntu-elisp/ppa sudo apt-get update sudo apt-get install ...
- Nginx+keepalive 负载均衡
1 规划和准备 两台相同配置的web 用途 IP MASTER 192.168.1.100 BACKUP 192.1681.101 2 安装 两台接入服务器分别安装NginX和keepalived: ...
- BZOJ 1150--数据备份(链表&堆&贪心)
1150: [CTSC2007]数据备份Backup Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2572 Solved: 1038[Submit ...