惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

T
Tenable Blog
Last Week in AI
Last Week in AI
P
Proofpoint News Feed
Engineering at Meta
Engineering at Meta
H
Help Net Security
F
Fortinet All Blogs
MyScale Blog
MyScale Blog
宝玉的分享
宝玉的分享
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
博客园 - 司徒正美
量子位
N
Netflix TechBlog - Medium
Apple Machine Learning Research
Apple Machine Learning Research
小众软件
小众软件
Recorded Future
Recorded Future
博客园 - 三生石上(FineUI控件)
Vercel News
Vercel News
aimingoo的专栏
aimingoo的专栏
I
InfoQ
Microsoft Security Blog
Microsoft Security Blog
Scott Helme
Scott Helme
The Last Watchdog
The Last Watchdog
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
IT之家
IT之家
AI
AI
WordPress大学
WordPress大学
Security Archives - TechRepublic
Security Archives - TechRepublic
Google Online Security Blog
Google Online Security Blog
U
Unit 42
V2EX - 技术
V2EX - 技术
MongoDB | Blog
MongoDB | Blog
Schneier on Security
Schneier on Security
博客园 - Franky
H
Heimdal Security Blog
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Jina AI
Jina AI
W
WeLiveSecurity
P
Privacy & Cybersecurity Law Blog
Cloudbric
Cloudbric
B
Blog RSS Feed
N
News | PayPal Newsroom
S
Securelist
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
I
Intezer
Hacker News - Newest:
Hacker News - Newest: "LLM"
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
博客园_首页
罗磊的独立博客
H
Hackread – Cybersecurity News, Data Breaches, AI and More
雷峰网
雷峰网

博客园 - 老公鸡

sharepoint 2010? Jsp中使用数据库连接池. MVC2 学习之 UrlRouting Oracle 基础学习之索引 Oracle基础学习之函数 Oracle 基本操作之sql语句 Oracle基本操作 Oracle 数据库学习一 小黑日记三 结束了 mvc 3 学习 第一天 准备 小黑 成长日记第二天 2011年6月15日,同事捡了一只小猫回来了 NHibernate 学习 第十二天 存储过程的使用 NHibernate 学习 第十一天 对多对的关系处理 NHibernate 学习 第十天 一对多的外键关系处理 NHibernate 学习 第九天 外键关系的处理之一对一 NHibernate学习 第八天 组件的运用 NHibernate学习 第七天 其它的学习资料 NHibernate学习 第六天 NHibernate 中的查询
NHibernate 学习第五天 用户表的增,删,改,查
老公鸡 · 2011-06-10 · via 博客园 - 老公鸡

1. 数据访问层

  需要一个类  UserSerivce.cs

View Code

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using NHibernate;
using llr.Models;

namespace llr.DAL
{
   public class UserService
    {
       static ISession session;
       public UserService()
       {
           session = new NHibernateHelper().GetSession();
       }

       public static bool Add(User u)
       {
           try
           {
               using (ITransaction ts = session.BeginTransaction())
               {
                   session.Save(u);
                   session.Flush();
                   ts.Commit();
               }
               return true;
           }
           catch (Exception ex)
           {
               throw ex;
           }
       }

       public static bool Update(User u)
       {
           try
           {
               using (ITransaction ts = session.BeginTransaction())
               {
                   session.Update(u);
                   session.Flush();
                   ts.Commit();
               }
               return true;
           }
           catch (Exception ex)
           {
               throw ex;
           }
       }

       public static bool Delete(User u)
       {
           try
           {
               using (ITransaction ts = session.BeginTransaction())
               {
                   session.Delete(u);
                   session.Flush();
                   ts.Commit();
               }
               return true;
           }
           catch (Exception ex)
           {
               throw ex;
           }
 
       }

       public static IList

<User> SelectAll()
       {
          return session.CreateSQLQuery("select * from users").AddEntity(typeof(User)).List
<User>();
       }
    }
}

2. 业务层

  需要一个类 UserManager.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using llr.Models;
using llr.DAL;namespace llr.BLL
{
   
public class UserManager
    {
       
public static bool Add(User u)
       {
           
return UserService.Add(u);
       }
public static bool Update(User u)
       {
           
return UserService.Update(u);
       }
public static bool Delete(User u)
       {
           
return UserService.Delete(u);
       }
public static IList<User> SelectAll()
       {
           
return UserService.SelectAll();
       }
    }
}

3. 表示层

  需要页面显示 用来显示所有的User信息,页面上放一个 GridView 控件

 protected void Page_Load(object sender, EventArgs e)
    {
        
if (!IsPostBack)
        {
            BindUserInfo();
        }
    }
void BindUserInfo()
    {
        IList
<llr.Models.User> us = llr.BLL.UserManager.SelectAll();
        
this.GridView1.DataSource = us;
        
this.GridView1.DataBind();
    }

4. 数据库结构 T-SQL

USE [MyNibernate]
GO
/****** Object:  Table [dbo].[Roles]    Script Date: 06/10/2011 15:40:24 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[Roles](
    
[rid] [int] IDENTITY(1,1NOT NULL,
    
[r_name] [nchar](10NULL,
    
[r_desc] [nchar](10NULL,
 
CONSTRAINT [PK_Roles] PRIMARY KEY CLUSTERED 
(
    
[rid] ASC
)
WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ONON [PRIMARY]
ON [PRIMARY]
GO
/****** Object:  Table [dbo].[Menus]    Script Date: 06/10/2011 15:40:24 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[Menus](
    
[mid] [int] NOT NULL,
    
[m_title] [nchar](10NULL,
    
[m_parnet] [int] NULL,
    
[m_url] [nchar](10NULL,
 
CONSTRAINT [PK_Menus] PRIMARY KEY CLUSTERED 
(
    
[mid] ASC
)
WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ONON [PRIMARY]
ON [PRIMARY]
GO
/****** Object:  Table [dbo].[Users]    Script Date: 06/10/2011 15:40:24 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[Users](
    
[Id] [int] IDENTITY(1,1NOT NULL,
    
[u_name] [nchar](10NULL,
    
[u_pwd] [nchar](10NULL,
    
[r_id] [int] NOT NULL,
 
CONSTRAINT [PK_Users] PRIMARY KEY CLUSTERED 
(
    
[Id] ASC
)
WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ONON [PRIMARY]
ON [PRIMARY]
GO
/****** Object:  Table [dbo].[RoleToMenu]    Script Date: 06/10/2011 15:40:24 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[RoleToMenu](
    
[rid] [int] NULL,
    
[mid] [int] NULL
ON [PRIMARY]
GO
/****** Object:  ForeignKey [FK_RoleToMenu_Menus]    Script Date: 06/10/2011 15:40:24 ******/
ALTER TABLE [dbo].[RoleToMenu]  WITH CHECK ADD  CONSTRAINT [FK_RoleToMenu_Menus] FOREIGN KEY([mid])
REFERENCES [dbo].[Menus] ([mid])
GO
ALTER TABLE [dbo].[RoleToMenu] CHECK CONSTRAINT [FK_RoleToMenu_Menus]
GO
/****** Object:  ForeignKey [FK_RoleToMenu_Roles]    Script Date: 06/10/2011 15:40:24 ******/
ALTER TABLE [dbo].[RoleToMenu]  WITH CHECK ADD  CONSTRAINT [FK_RoleToMenu_Roles] FOREIGN KEY([rid])
REFERENCES [dbo].[Roles] ([rid])
GO
ALTER TABLE [dbo].[RoleToMenu] CHECK CONSTRAINT [FK_RoleToMenu_Roles]
GO
/****** Object:  ForeignKey [FK_Users_Roles]    Script Date: 06/10/2011 15:40:24 ******/
ALTER TABLE [dbo].[Users]  WITH CHECK ADD  CONSTRAINT [FK_Users_Roles] FOREIGN KEY([r_id])
REFERENCES [dbo].[Roles] ([rid])
GO
ALTER TABLE [dbo].[Users] CHECK CONSTRAINT [FK_Users_Roles]
GO

 我在这里:源代码