Nhibernate的第一個實例

来源:http://www.cnblogs.com/cnwisdom/archive/2016/05/25/5526593.html
-Advertisement-
Play Games

第一個NhIbernate程式 1、目的: a) 鏈接到oracle資料庫 b) 增刪改 c) 基本查詢、sql查詢 d) 視圖查詢 e) 使用存儲過程 f) 多表查詢、級聯查詢 g) 級聯增刪改 2、後續目的 a) 載入機制——立即載入or延遲載入 b) 併發控制 c) 緩存——一級緩存,二級緩存 ...


第一個NhIbernate程式

 

1、目的:

a) 鏈接到oracle資料庫

b) 增刪改

c) 基本查詢、sql查詢

d) 視圖查詢

e) 使用存儲過程

f) 多表查詢、級聯查詢

g) 級聯增刪改

 

2、後續目的

a) 載入機制——立即載入or延遲載入

b) 併發控制

c) 緩存——一級緩存,二級緩存

 

   接下來我會一一完成上面的目的,以便對Hhibernate有更多的瞭解,寫希望各位能多多的指正。

 

3、第一個項目

a) 下載

Nhibernate最新版本為4.0.1.GA,下載地址:http://nhforge.org/

 

下載內容如下圖

 

 

其中  Configuration_Templates中放的是各個資料庫連接的配置文件樣本模板,基本上包含了主流的資料庫

 

B) 創建項目

根據三層架構把項目分為三層:

第一層: Model層——主要存放數據實體與映射文件

第二層: DAL層——存放資料庫的操作方法

第三層: Facade層——業務邏輯層,主要實現與頁面的業務邏輯

第四層: View層——頁面層,包含介面、web

第五層:Common層——公共類層,主要存儲一些共有的操作類

 

由於分五層為個人習慣問題,有不習慣的園友可以分三層:去掉第三層與第五層。

        分佈圖如下

       

    

 

  C) 引用DLL文件 (這裡介紹主要的幾個引用,其他的話,可以根據我放出的實例來看)

         Model層: 需要引入Required_Bins 文件夾中的Iesi.Collections.dllNHibernate.dll

         DAL層 :  需要引入Required_Bins 文件夾中的Iesi.Collections.dllNHibernate.dllModel層;

         Facade層:需要引入Model層與DAL層;

         View層:  需要引入Required_Bins 文件夾中的Iesi.Collections.dllNHibernate.dlllog4net.dllModel層與Facade層;

   

        其實還有另一種方法可以添加引用,就是通過NuGet進行引用,這種方法我在這裡就不介紹了。

 

     D) 創建資料庫

        先在oracle資料庫中創建一張表,如圖

 

      該表沒有任何外鍵關聯,也沒其他表的ID欄位。

 

E)創建model層中的持久化類 及 xml映射文件

創建cat的類

 

創建catmapping對應的xml文件

 

 

基本文件位置如下

 

 

    F)修改配置文件

      因為連接的是oracle的資料庫,所以在下載的文件Configuration_Templates文件夾中找到oracle的配置文件,如圖  

     

  選擇oracle.cfg.xml 文件 放到View層下麵 ,並且修改名字。預設的名字是hibernate.cfg.xml,且需要放在bin——debug文件夾下麵。大多數情況我們會根據自身的習慣進行一些調整。比如我喜歡放在App_Data文件夾下。

   

 

    修改配置文件信息

        原始的配置文件信息

 

        我修改後的文件信息

 

    G)編寫DAL方法與實例

 

首先  先寫一個NhibernateHelper.cs文件

 1 using System;
 2 using System.Collections.Generic;
 3 using System.Linq;
 4 using System.Text;
 5 using System.Threading.Tasks;
 6 
 7 using NHibernate;
 8 using NHibernate.Linq;
 9 using NHibernate.Criterion;
10 
11 namespace CommonClass
12 {
13    public class NHibernateHelper
14     {
15        /// <summary>
16         /// Session工廠
17         /// </summary>
18         private  readonly ISessionFactory SessionFactory;
19         /// <summary>
20         /// nhibernate.cfg.xml 所在相對路徑
21         /// </summary>
22         private  string xmlString = "App_Data/hibernate.cfg.xml";
23         /// <summary>
24         /// 構造函數
25         /// </summary>
26         public NHibernateHelper()
27         {
28             if (SessionFactory == null)
29             {
30                 var cfg = new NHibernate.Cfg.Configuration().Configure(xmlString);
31                
32                 SessionFactory = cfg.BuildSessionFactory();
33                 
34             }
35         }
36 
37        public NHibernateHelper(string path)
38         {
39             if (SessionFactory == null)
40             {
41                 var cfg = new NHibernate.Cfg.Configuration().Configure(path);
42 
43                 SessionFactory = cfg.BuildSessionFactory();
44             }
45         }
46 
47         /// <summary>
48         /// 獲取一個Isession
49         /// </summary>
50         /// <returns></returns>
51         public ISession GetSession()
52         {
53             return SessionFactory.OpenSession();
54         }
55         /// <summary>
56         /// 關閉一個Isession
57         /// </summary>
58         /// <param name="session"></param>
59         public void CloseSeeion(ISession session)
60         {
61             session.Close();
62         }
63 
64         /// <summary>
65         /// 關閉一個Isessionfactory
66         /// </summary>
67         public void CloseSessionFactory()
68         {
69             SessionFactory.Close();
70         }
71     }
72 }

   再編寫CATDAL.cs  用來操作資料庫的方法

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using NHibernate;
using NHibernate.Linq;
using NHibernate.Criterion;

using ModelEntityClass.Model;
using CommonClass;

namespace DALClass
{
    public class CATDAL
    {
        private  NHibernateHelper HB_Helper = null;
        public CATDAL()
        {
            HB_Helper = new NHibernateHelper();
        }
        /// <summary>
        /// 添加
        /// </summary>
        /// <param name="entitys"></param>
        /// <returns></returns>
        public bool InsertAll(List<CAT> entitys)
        {
            bool flag = false;
            ISession session = HB_Helper.GetSession();
            using (ITransaction tt = session.BeginTransaction())
            {
                try
                {
                    foreach (CAT entity in entitys)
                    {
                        session.Save(entity);
                    }
                    session.Flush();
                    tt.Commit();
                    flag = true;
                }
                catch (HibernateException ex)
                {
                    tt.Rollback();
                }
            }

            HB_Helper.CloseSeeion(session);
            return flag;
        }
        /// <summary>
        /// 根據ID進行查找
        /// </summary>
        /// <param name="id"></param>
        /// <returns></returns>
        public CAT Find(string id)
        {
            ISession session = HB_Helper.GetSession();
            CAT cat = null;
            using (ITransaction tt = session.BeginTransaction())
            {
                try
                {
                    cat = session.Query<CAT>().Where(p => p.ID == id).FirstOrDefault();
                }
                catch (HibernateException ex)
                {
                    tt.Rollback();
                }
            }

            HB_Helper.CloseSeeion(session);
            return cat;
        }
        /// <summary>
        /// 查詢所有
        /// </summary>
        /// <returns></returns>
        public List<CAT> FindAll()
        {
            ISession session = HB_Helper.GetSession();
            //ICriteria criteria = session.CreateCriteria(typeof(CAT));
            List<CAT> catList = null;
            using (ITransaction tt = session.BeginTransaction())
            {
                try
                {
                    catList = session.Query<CAT>().ToList();
                }
                catch (HibernateException ex)
                {
                    tt.Rollback();
                }
            }

            HB_Helper.CloseSeeion(session);
            return catList;
        }

        /// <summary>
        /// 刪除所有
        /// </summary>
        /// <param name="entitys"></param>
        /// <returns></returns>
        public bool DeleteAll(List<CAT> entitys)
        {

            bool flag = false;
            ISession session = HB_Helper.GetSession();
            using (ITransaction tt = session.BeginTransaction())
            {
                try
                {
                    foreach (CAT entity in entitys)
                    {
                        session.Delete(entity);
                    }
                    session.Flush();
                    tt.Commit();
                    flag = true;
                }
                catch (HibernateException ex)
                {
                    tt.Rollback();
                }
            }

            HB_Helper.CloseSeeion(session);
            return flag;

        }

        /// <summary>
        /// 刪除
        /// </summary>
        /// <param name="entity"></param>
        /// <returns></returns>
        public bool Delete(CAT entity)
        {

            bool flag = false;
            ISession session = HB_Helper.GetSession();
            using (ITransaction tt = session.BeginTransaction())
            {
                try
                {
                    session.Delete(entity);

                    session.Flush();
                    tt.Commit();
                    flag = true;
                }
                catch (HibernateException ex)
                {
                    tt.Rollback();
                }
            }

            HB_Helper.CloseSeeion(session);
            return flag;

        }


        /// <summary>
        /// 保存和添加
        /// </summary>
        /// <param name="entity"></param>
        /// <returns></returns>
        public bool SaveAndUpdate(List<CAT> entitys)
        {
            bool flag = false;
            ISession session = HB_Helper.GetSession();
            using (ITransaction tt = session.BeginTransaction())
            {
                try
                {
                    foreach (CAT entity in entitys)
                    {
                        session.SaveOrUpdate(entity);
                    }
                    session.Flush();
                    tt.Commit();
                    flag = true;
                }
                catch (HibernateException ex)
                {
                    tt.Rollback();
                }
            }

            HB_Helper.CloseSeeion(session);
            return flag;
        }
    }
}
View Code

 

   接下來編輯業務邏輯層的類,由於它是對應ConsoleApplication1項目的這個業務,我把他命名成ConsoleFacade(裡面只有一個方法,後面可以根據需要進行添加)

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using ModelEntityClass.Model;
using DALClass;

namespace FacadeClass
{
   public  class ConsoleFacade
    {

       public bool InsertAll(List<CAT> entitys)
       {
           CATDAL dal = new CATDAL();
           return dal.InsertAll(entitys);
       }
    }
}
View Code

   現在我們進行測試

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using ModelEntityClass.Model;
using FacadeClass;

namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            CAT cat = new CAT();

            cat.ID = Guid.NewGuid().ToString();

            cat.NAME = "芝麻";
            cat.SHORTNAME = "小婊砸";
            cat.CREATDATA = DateTime.Now;
            cat.ADDRESS = "北京市不知道什麼的地方";
            cat.AGE = 2;
            cat.CODE = "M0001";

            List<CAT> InsertList = new List<CAT> ();
            InsertList.Add(cat);

            ConsoleFacade facade = new ConsoleFacade();
           if(  facade.InsertAll(InsertList))
           {
               Console.WriteLine("添加成功");
           }else
           {
               Console.WriteLine("添加失敗");
           }

           Console.ReadKey();
        }
    }
}
View Code

   測試頁面如下

 

這樣我們一個簡單的Nhibernate實例就完成了。

 

 項目實例下載 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Centos6.6 下載地址:thunder://QUFodHRwOi8vbGludXguemh1YW5neGl0b25nLmNvbTo4MDgvMjAxNTAxL0NlbnRPUy02LjYteDg2XzY0LWJpbi1EVkQxLmlzb1pa 1、首先要下載一個centos的iso鏡像,我是 ...
  • 不廢話,直接上如何利用Asp.NET操作XML文件,並對其屬性進行修改,剛開始的時候,是打算使用JS來控制生成XML文件的,但是最後卻是無法創建文件,讀取文件則沒有使用了 index.aspx 文件 index.aspx.cs文件 Command.cs 文件 UserEdit.aspx UserEd ...
  • 1、var 1、均是聲明動態類型的變數。 2、在編譯階段已經確定類型,在初始化的時候必須提供初始化的值。 3、無法作為方法參數類型,也無法作為返回值類型。 2、dynamic 1、均是聲明動態類型的變數。 2、運行時檢查類型,不存在語法類型,在初始化的時候可以不提供初始化的值。 3、反射時簡化代碼, ...
  • 1、通過Nuget下載CORS安裝包 2、在WebApiConfig.cs文件中註冊CORS 3、在全局文件啟用CORS支持 4、在控制器上添加頭 ...
  • 今天ModestMT.Zou發佈了DotnetSpider爬蟲第二章節,內容簡單明瞭,基本看懂了,於是想自己試試看,直接就拿博客園開刀了。 這裡有最基本的使用方式,本文章不介紹 [開源 .NET 跨平臺 數據採集 爬蟲框架: DotnetSpider] [二] 最基本,最自由的使用方式 這裡我已經從 ...
  • 本著簡潔直接,我們就直奔主題吧! 下麵是一個生成數字和字母隨機組合的驗證碼類源代碼: using System; using System.Drawing; using System.Drawing.Imaging; using System.Web.UI; using System.Drawing ...
  • 1. 2.跳轉的另一個頁面 3.Get傳值:跳轉頁面.cs頁面 4. 跳轉頁面前端頁面 效果顯示: ...
  • DataTable dtPCI = dtblSourceData.DefaultView.ToTable(true, new string[] { "Server Cell PCI" }); 根據現有 DataView 中的行,創建並返回一個新的 DataTable。 命名空間:System.Dat ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...