用Nhibernate怎么实现数据的添加、删除、修改简单程序

2024-02-21 08:48

本文主要是介绍用Nhibernate怎么实现数据的添加、删除、修改简单程序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

Nhibernate怎么实现数据的添加、删除、修改简单程序

 

一、创建数据库

数据库名:Nhibernate
u
se NHibernate
go
CREATE TABLE users ( 
  LogonID nvarchar(20) NOT NULL default '0',
  Name nvarchar(40) default NULL,
  Password nvarchar(20) default NULL,
  EmailAddress nvarchar(40) default NULL,
  PRIMARY KEY  (LogonID)
)
go

数据表:users

 

二、总体介绍

项目名:WebNhibernate

界面:WebForm.aspx

具体表现文件:WebForm.aspx.cs

实体类文件:EntityClass.cs

映射文件:Userhbm.xml

配置文件:Web.config

 

三、创建Web界面

类型

对象名

Text属性值

Label

Label1

ID:

Label

Label2

姓名:

Label

Label3

密码:

Label

Label4

Email

Label

Labmessage

 

TextBox

TxtId

 

TextBox

TxtName

 

TextBox

TxtPassword

 

TextBox

TxtEmail

 

Button

ButSave

添加

Button

ButDel

删除

Button

ButUpdata

修改

 

四、创建映射文件(xml文件)和实体类

实体类

using System;

namespace WebNhibernate

{

     public class EntityClass

     {

          private string id;

          private string userName;

          private string password;

          private string emailAddress;

         public EntityClass()

         {}

         public string Id

         {

              get { return id; }

              set { id = value; }

         }

         public string UserName

         {

              get { return userName; }

              set { userName = value; }

         }

         public string Password

         {

              get { return password; }

              set { password = value; }

         }

         public string EmailAddress

         {

              get { return emailAddress; }

              set { emailAddress = value; }

         }

     }

}

映射文件:

<?xml version="1.0" encoding="utf-8" ?>

<hibernate-mapping xmlns="urn:nhibernate-mapping-2.0">

     <class name="WebNhibernate.EntityClass, WebNhibernate" table="users">

         <id name="Id" column="LogonId" type="String" length="20">

              <generator class="assigned" />

         </id>

          <property name="UserName" column= "Name" type="string" length="40"/>

          <property name="Password" type="string" length="20"/>

          <property name="EmailAddress" type="String" length="40"/>

     </class>

</hibernate-mapping>

注意点:

1<class name="WebNhibernate.EntityClass, WebNhibernate" table="users">

       WebNhibernate.EntityClass代表:实体类名

    WebNhibernate代表:该项目的装配集名称

      Users代表:数据表名

2.当属性列表<property name=”” column=””/>中既有name和column说明实体层的属性与数据表的字段名不同名

3.指定一个id, 在数据表中就是主键, 这个非常重要,nhibernate就是通过id来判断对象的唯一性的.

 

五、在配置文件中添加配置内容

1.首先在配置文件的<configuration>代码下面添加如下代码

       <configSections>

             <section name="nhibernate" type="System.Configuration.NameValueSectionHandler, System, Version=1.0.3300.0,Culture=neutral, PublicKeyToken=b77a5c561934e089" />

     </configSections> 

     这一段代码是必须要的

2.在配置文件的</system.web>代码下面添加如下代码

<nhibernate>

         <!连接数据提供者 -->

         <add

              key="hibernate.connection.provider"         

              value="NHibernate.Connection.DriverConnectionProvider"

         />

         <!连接数据方言最常用的是MsSql2000Dialect -->

         <add

              key="hibernate.dialect"                     

              value="NHibernate.Dialect.MsSql2000Dialect"

         />

         <!连接数据驱动类-->

         <add

              key="hibernate.connection.driver_class"         

              value="NHibernate.Driver.SqlClientDriver"

         />

         <!连接数据库-->

         <add

              key="hibernate.connection.connection_string"

              value="Server=yanfa1;initial catalog=nhibernate;User id=sa;password=8626798;"

         />

</nhibernate>

 

六、实现代码

首先在文件头添加代码
using NHibernate;
using NHibernate.Cfg;
1.添加数据:

双击“添加“按钮

        private void ButSave_Click(object sender, System.EventArgs e)

         {

              mCfg=new Configuration();//创建配置类

              mCfg.AddXmlFile (System.Web.HttpContext.Current.Server.MapPath("Userhbm.xml"));//指明映射文件Userhbm.xml

              EntityClass vEntity=new EntityClass();

              vEntity.Id=TxtId.Text;

              vEntity.UserName=TxtName.Text;

              vEntity.Password=TxtPassword.Text;

              vEntity.EmailAddress=TxtEmail.Text;

              ISession vSession= mCfg.BuildSessionFactory().OpenSession();//创建会话工厂, 一般来说应该使用一个单例对象来封装会话工厂.

              ITransaction vTransaction = vSession.BeginTransaction();//创建事物处理

              try

              {

                   vSession.Save(vEntity);//向数据库添加数据

                   vTransaction.Commit();

                   Labmessage.Text="OK";

              }

              catch(Exception ex)

              {

                   vTransaction.Rollback();

                   Labmessage.Text="Error"+ex.ToString();

              }

              finally

              {

                   vSession.Close();

              }

         }

 

2.删除数据:

双击“删除“按钮
        private void ButDel_Click(object sender, System.EventArgs e)

         {

              mCfg=new Configuration();

              mCfg.AddXmlFile (System.Web.HttpContext.Current.Server.MapPath("Userhbm.xml"));

              ISession vSession= mCfg.BuildSessionFactory().OpenSession();

              ITransaction vTransaction = vSession.BeginTransaction();

              try

              {

                   EntityClass vEntity=(EntityClass) vSession.Load(typeof(EntityClass),TxtId.Text);//查找数据表中所要记录

                   vSession.Delete(vEntity);//向数据库删除数据

                   vTransaction.Commit();

                   Labmessage.Text="OK";

              }

              catch(Exception ex)

              {

                   vTransaction.Rollback();

                   Labmessage.Text="Error";

              }

              finally

              {

                   vSession.Close();

              }

         }

 

3.修改代码:

双击“修改“按钮
        private void ButUpdata_Click(object sender, System.EventArgs e)

         {

              mCfg=new Configuration();

              mCfg.AddXmlFile (System.Web.HttpContext.Current.Server.MapPath("Userhbm.xml"));

              ISession vSession= mCfg.BuildSessionFactory().OpenSession();

              ITransaction vTransaction = vSession.BeginTransaction();

              try

              {

                   EntityClass vEntity=(EntityClass) vSession.Load(typeof(EntityClass),TxtId.Text);

                   vEntity.UserName=TxtName.Text;

                   vEntity.Password=TxtPassword.Text;

                   vEntity.EmailAddress=TxtEmail.Text;

                   vSession.Update(vEntity); //向数据库修改数据

                   vTransaction.Commit();

                   Labmessage.Text="OK";

              }

              catch(Exception ex)

              {

                   vTransaction.Rollback();

                   Labmessage.Text="Error";

              }

              finally

              {

                   vSession.Close();

              }

         }

这篇关于用Nhibernate怎么实现数据的添加、删除、修改简单程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/731203

相关文章

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构