如何在.NET Core應(yīng)用中使用NHibernate詳解
前言
Nhibernate 來源于非常優(yōu)秀的基于Java的Hibernate 關(guān)系型持久化工具。NHibernate 最近發(fā)布了 5.1.3 版本, 支持 .NET Standard 2.0 , 這意味著可以在 .NET Core 2.0 應(yīng)用中使用, 本文就已 WebAPI 應(yīng)用為例, 介紹一下如何在 .NET Core 應(yīng)用中如何使用 NHibernate 。下面話不多說了,來一起看看詳細(xì)的介紹的吧
使用方法如下:
1、 新建一個(gè)基于 .NET Core 的 Web API應(yīng)用, 命令如下:
mkir WebApiTest cd WebApiTest/ dotnet new webapi
2、 添加 NHibernate 包以及對(duì)應(yīng)的數(shù)據(jù)庫驅(qū)動(dòng)程序(以 Npgsql 為例):
dotnet add pakcage NHibernate dotnet add package NHibernate.NetCore dotnet add package Npgsql
現(xiàn)在打開項(xiàng)目文件 WebApiTest.csproj , 可以看到已經(jīng)添加了這些包:
<ItemGroup> <PackageReference Include="Microsoft.AspNetCore.App" /> <PackageReference Include="NHibernate" Version="5.1.3" /> <PackageReference Include="NHibernate.NetCore" Version="1.0.1" /> <PackageReference Include="NpgSql" Version="4.0.2" /> </ItemGroup>
3、 在項(xiàng)目中新建一個(gè) Models 目錄, 并創(chuàng)建實(shí)體類以及對(duì)應(yīng)的 xml 映射文件, 代碼如下:
namespace WebApiTest.Models {
public class GpsPosition {
public virtual long Id { get; set; }
public virtual string UserAgent { get; set;}
public virtual long? Timestamp { get; set; }
public virtual float? Latitude { get; set; }
public virtual float? Longitude { get; set; }
public virtual float? Accuracy { get; set; }
public virtual float? Altitude { get; set; }
public virtual float? AltitudeAccuracy { get; set; }
public virtual float? Heading { get; set; }
public virtual float? Speed { get; set; }
public virtual string Tag { get; set; }
}
}
對(duì)應(yīng)的 xml 映射文件如下:
<?xml version="1.0" encoding="utf-8"?> <hibernate-mapping xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns="urn:nhibernate-mapping-2.2" namespace="WebApiTest.Models" assembly="WebApiTest"> <class name="GpsPosition" schema="public" table="gps_position"> <id name="Id" column="id" type="long"> <generator class="sequence"> <param name="sequence">public.gps_position_id_seq</param> </generator> </id> <property name="UserAgent" column="user_agent" type="string" /> <property name="Timestamp" column="timestamp" type="long" /> <property name="Latitude" column="latitude" type="float" /> <property name="Longitude" column="longitude" type="float" /> <property name="Accuracy" column="accuracy" type="float" /> <property name="Altitude" column="altitude" type="float" /> <property name="AltitudeAccuracy" column="altitude_accuracy" type="float" /> <property name="Heading" column="heading" type="float" /> <property name="Speed" column="speed" type="float" /> <property name="Tag" column="tag" type="string" /> </class> </hibernate-mapping>
這些都是 NHibernate 的常規(guī)做法, 因此不做過多介紹, 不熟悉的可以查閱 NHIbernate 的相關(guān)文檔。
4、 將 xml 文件編譯為嵌入的資源, 打開項(xiàng)目文件 WebApiTest.csproj , 添加一個(gè) ItemGroup 節(jié)點(diǎn):
<ItemGroup> <None Remove="Models/*.hbm.xml" /> <EmbeddedResource Include="Models/*.hbm.xml" /> </ItemGroup>
5、 創(chuàng)建 NHibernate 的配置文件, 并設(shè)置為復(fù)制到輸出目錄:
<?xml version="1.0" encoding="UTF-8"?> <hibernate-configuration xmlns="urn:nhibernate-configuration-2.2"> <session-factory> <property name="connection.connection_string">server=localhost;database=test_db;user id=postgres;password=postgres;</property> <property name="dialect">NHibernate.Dialect.PostgreSQL83Dialect</property> <property name="connection.driver_class">NHibernate.Driver.NpgsqlDriver</property> <property name="show_sql">true</property> <property name="format_sql">true</property> <property name="adonet.batch_size">10</property> <mapping assembly="NaturalReserveApi" /> </session-factory> </hibernate-configuration>
打開項(xiàng)目文件, 添加 ItemGroup 節(jié)點(diǎn), 內(nèi)容如下:
<ItemGroup> <Content Update="hibernate.config"> <CopyToOutputDirectory>Always</CopyToOutputDirectory> </Content> </ItemGroup>
6、 修改 Startup.cs 文件, 將 NHibernate 集成到 .NET Core 內(nèi)置的依賴注入框架中:
6.1、 修改 Startup.cs 的 using 部分, 添加下面的語句:
using Microsoft.Extensions.Logging; using NHibernate.NetCore;
6.2、 修改 Startup.cs 的構(gòu)造函數(shù), 代碼如下:
public Startup(
IConfiguration configuration,
ILoggerFactory factory
) {
Configuration = configuration;
// 將內(nèi)置的日志組件設(shè)置為 NHibernate 的日志組件
factory.UseAsHibernateLoggerFactory();
}
6.3、 修改 ConfigureServices 方法, 添加 NHibernate 相關(guān)的服務(wù):
public void ConfigureServices(IServiceCollection services) {
// nhibernate 配置文件的路徑
var path = System.IO.Path.Combine(
AppDomain.CurrentDomain.BaseDirectory,
"hibernate.config"
);
// 添加 NHibernate 相關(guān)的服務(wù)
services.AddHibernate(path);
services.AddMvc()
.SetCompatibilityVersion(CompatibilityVersion.Version_2_1);
}
7、 修改默認(rèn)的 ValuesController.cs , 注入并使用 NHibernate:
7.1、 修改構(gòu)造函數(shù), 注入 ISessionFactory :
public ValuesController(ISessionFactory factory) {
this.factory = factory;
}
7.2、 修改 Get 方法, 使用 NHibernate 進(jìn)行查詢:
// GET api/values
[HttpGet]
public ActionResult<IEnumerable<GpsPosition>> Get() {
using (var session = factory.OpenSession()) {
var query = session.Query<GpsPosition>();
return query.ToList();
}
}
8、 編譯并運(yùn)行:
dotnet run
之后可以看到類似這樣的 NHibernate 初始化信息:
Using launch settings from ~/Projects/WebApiTest/Properties/launchSettings.json... info: NHibernate.Cfg.Environment[0] NHibernate 5.1.3 (assembly 5.1.0.0) info: NHibernate.Cfg.Environment[0] hibernate-configuration section not found in application configuration file info: NHibernate.Cfg.Environment[0] Bytecode provider name : lcg info: NHibernate.Cfg.Environment[0] Using reflection optimizer dbug: NHibernate.Cfg.Configuration[0] ...... Hosting environment: Development Content root path: ~/Projects/WebApiTest Now listening on: https://localhost:5001 Now listening on: http://localhost:5000 Application started. Press Ctrl+C to shut down.
看到這些信息, 就表示已經(jīng)可以正常的使用 NHibernate 了。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
- Hibernate中Session.get()方法和load()方法的詳細(xì)比較
- Hibernate用ThreadLocal模式(線程局部變量模式)管理Session
- hibernate測(cè)試時(shí)遇到的幾個(gè)異常及解決方法匯總
- Hibernate中使用HQLQuery查詢?nèi)繑?shù)據(jù)和部分?jǐn)?shù)據(jù)的方法實(shí)例
- Hibernate實(shí)現(xiàn)many-to-many的映射關(guān)系
- Hibernate一級(jí)緩存和二級(jí)緩存詳解
- SpringBoot 使用hibernate validator校驗(yàn)
- Hibernate之CRUD操作實(shí)踐
- Springboot+hibernate實(shí)現(xiàn)簡(jiǎn)單的增刪改查示例
- Hibernate的各種保存方式的區(qū)別詳解
相關(guān)文章
asp.net使用ODP即oracle連接方式的的防注入登錄驗(yàn)證程序
這篇文章主要介紹了asp.net使用ODP即oracle連接方式的的防注入登錄驗(yàn)證程序,需要的朋友可以參考下2014-05-05
ASP.NET在IIS上注冊(cè)報(bào)0x800702e4錯(cuò)誤解決方法
報(bào)一個(gè)0x800702e4 請(qǐng)求的操作需要提升的錯(cuò)誤。解決的方法和前面大同小異,給這個(gè)aspnet_regiis.exe創(chuàng)建一個(gè)快捷方式,給它的目標(biāo)后面加上 一個(gè)-i,再右擊這個(gè)快捷方式,以管理員身份運(yùn)行,就行了2012-08-08
ASP.NET對(duì)路徑"xxxxx"的訪問被拒絕的解決方法小結(jié)
異常詳細(xì)信息: System.UnauthorizedAccessException: 對(duì)路徑“D:/temp1/MyTest.txt”的訪問被拒絕2012-09-09
VS2015自帶LocalDB數(shù)據(jù)庫用法詳解
這篇文章主要為大家詳細(xì)介紹了VS2015自帶LocalDB數(shù)據(jù)庫的用法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
ASP.NET?Core管理應(yīng)用程序狀態(tài)
這篇文章介紹了ASP.NET?Core管理應(yīng)用程序狀態(tài)的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-04-04
微軟官方SqlHelper類 數(shù)據(jù)庫輔助操作類
本文主要介紹微軟官方的數(shù)據(jù)庫操作類極其使用方法,幫助大家利用已經(jīng)非常成熟的類庫來進(jìn)行快速開發(fā)。2016-03-03
基于.net standard 的動(dòng)態(tài)編譯實(shí)現(xiàn)代碼
這篇文章主要介紹了基于.net standard 的動(dòng)態(tài)編譯實(shí)現(xiàn)代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-07-07
asp.net讀取excel中的數(shù)據(jù)并綁定在gridview
這篇文章主要介紹了asp.net讀取excel中的數(shù)據(jù)并綁定在gridview上的方法,需要的朋友可以參考下2014-02-02
獲取ashx得到的內(nèi)容(已處理好的數(shù)據(jù))
獲取ashx得到的內(nèi)容,一般用于ajax的情況比較多一點(diǎn);重點(diǎn):ashx頁面?zhèn)鬟^來的就是已經(jīng)處理好的數(shù)據(jù),感興趣的朋有可以參考下啊,希望本文對(duì)你學(xué)習(xí)ajax有所幫助2013-01-01
SQL Server數(shù)據(jù)庫連接 Web.config如何配置
以下的文章主要描述的是Web.config正確配置SQL Server數(shù)據(jù)庫連接的實(shí)際擦步驟。我們以圖文結(jié)合的方式對(duì)其有個(gè)更好的說明,需要的朋友可以參考下2015-10-10

