NHibernate案例

参考:NHibernate中文帮助文档:.NET ORM框架全面指南-CSDN博客

NHibernate之旅系列文章导航 - 李永京 - 博客园

Your first NHibernate based application - NHibernate

创建Winform应用程序

创建Winform项目NHibernate,NuGet引入NHibernate包

创建数据库表

sql 复制代码
USE MASTER
GO

IF EXISTS (SELECT TOP 1 1 FROM SYSDATABASES WHERE NAME='Demo')
	DROP DATABASE Demo
GO

CREATE DATABASE Demo
GO

USE Demo
GO

IF EXISTS (SELECT TOP 1 1 FROM SYSOBJECTS WHERE NAME='TestTable')
	DROP TABLE TestTable
GO

CREATE TABLE TestTable
(
	Id NVARCHAR(50) PRIMARY KEY NOT NULL,
	Contents NVARCHAR(100)
)
GO

创建实体类和xml文件

TestTable.cs

属性一定要加Virtual

cs 复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace NHibernateDemo.Entity
{
    public class TestTable
    {
        public virtual string Id {  get; set; }
        public virtual string Contents {  get; set; }
    }
}

TestTable.hbm.xml

主键一定要用Id标签写,固定写法

XML 复制代码
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
                   assembly="NHibernateDemo"
                   namespace="NHibernateDemo.Entity">

  <class name="TestTable" table="TestTable">
    <id name="Id" column="Id" type="String">
      <generator class="native"/>
    </id>

    <property name="Contents" column="Contents" type="String"/>
  </class>
</hibernate-mapping>

hibernate.cfg.xml

XML 复制代码
<!-- 示例的hibernate.cfg.xml配置 -->
<hibernate-configuration xmlns="urn:nhibernate-configuration-2.2">
  <session-factory>
    <!-- 数据库连接设置 -->
    <property name="connection.provider">NHibernate.Connection.DriverConnectionProvider</property>
    <property name="connection.driver_class">NHibernate.Driver.Sql2008ClientDriver</property>
    <property name="connection.connection_string">Server=.;Database=Demo;User Id=sa;Password=123;</property>
    <!-- SQL方言 -->
    <property name="dialect">NHibernate.Dialect.MsSql2008Dialect</property>
    <!-- 映射文件的位置 -->
    <mapping assembly="NHibernateDemo" resource="NHibernateDemo.Entity.TestTable.hbm.xml"/>
  </session-factory>
</hibernate-configuration>

创建SessionFactory的类

cs 复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using NHibernate;

namespace NHibernateDemo
{
    public class MySessionFactory
    {
        private static ISessionFactory _sessionFactory;

        private static ISessionFactory SessionFactory
        {
            get
            {
                if (_sessionFactory == null)
                {
                    var configuration = new NHibernate.Cfg.Configuration();
                    _sessionFactory = configuration.Configure("hibernate.cfg.xml")
                        .BuildSessionFactory();
                }
                return _sessionFactory;
            }
        }

        public static ISession OpenSession()
        {
            return SessionFactory.OpenSession();
        }
    }
}

查询

cs 复制代码
private void BtnQuery_Click(object sender, EventArgs e)
{
    using (var session = MySessionFactory.OpenSession())
    {
        var list = session.QueryOver<TestTable>().List().ToList();
    }
}
相关推荐
极限实验室3 小时前
APM(一):Skywalking 与 Easyearch 集成
数据库·云原生
饕餮争锋3 小时前
SQL条件中WHERE 1=1 的功能
数据库·sql
玄斎4 小时前
MySQL 单表操作通关指南:建库 / 建表 / 插入 / 增删改查
运维·服务器·数据库·学习·程序人生·mysql·oracle
编织幻境的妖4 小时前
SQL查询连续登录用户方法详解
java·数据库·sql
编程小Y5 小时前
MySQL 与 MCP 集成全解析(核心原理 + 实战步骤 + 应用场景)
数据库·mysql·adb
零度@5 小时前
SQL 调优全解:从 20 秒到 200 ms 的 6 步实战笔记(附脚本)
数据库·笔记·sql
Miss_Chenzr5 小时前
Springboot优卖电商系统s7zmj(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
lvbinemail5 小时前
Grafana模板自动复制图表
数据库·mysql·zabbix·grafana·监控
Miss_Chenzr5 小时前
Springboot旅游景区管理系统9fu3n(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·旅游
小虾米vivian6 小时前
dmetl5 运行失败,提示违反协议?
数据库·达梦数据库