Chinaunix首页 | 论坛 | 博客
  • 博客访问: 372670
  • 博文数量: 132
  • 博客积分: 3066
  • 博客等级: 中校
  • 技术积分: 781
  • 用 户 组: 普通用户
  • 注册时间: 2009-04-14 16:19
文章分类

全部博文(132)

文章存档

2012年(1)

2010年(50)

2009年(81)

我的朋友

分类: C/C++

2009-06-15 00:19:30

SQLite 与 NHibernate 在 .NET 程序中使用


SQLite 与 NHibernate 在 .NET 程序中使用

作者:终南   <>

1。抛弃Access

曾经在VB下作一个程序,为了简单起见,通过共享目录来实现多台机器访问Access数据库,最终却发现这是个噩梦,程序根本没有办法正常运行,不得已采用Mysql。

最近作一个单机桌面程序,想采用Access+NHibernate来实现对数据库的操作,初次试验便告失败,索性不去理它,转而采用SQLite。

2。相关软件

Hibernate是一个Java编写的非常优秀的数据访问框架,它彻底屏蔽了使用SQL语句对数据库的操作,在Hibernate下,对数据库的操作简化为成对象的操作。NHibernate是Hibernate的.Net版本。当前NHibernate最新的稳定版本为1.2.1.GA,可以通过以下页面选择下载:

NHibernate包括.Net 1.1 和 .Net 2.0两个版本,以我们将要用到的2.0为例,解压下载后的软件得到以下我们需要用到的重要文件:

Castle.DynamicProxy.dll
Iesi.Collections.dll
log4net.dll
NHibernate.dll

SQLite是一个类似于Access的嵌入式、轻量级的小型数据库引擎,无数的软件或系统都采用SQLite作为数据库保存应用数据,如 Firefox, Iphone等。与其它大多数SQL数据库不同的是,SQLite没有独立的服务进程。SQLite直接读写原始的磁盘文件,一个拥有多个表、索引、触发器和视图的完整SQL数据库就包含在一个独立的磁盘文件中。数据库文件的格式是跨平台的,你可以在32位和64位系统之间、在不同的操作系统之间自由地复制数据库。SQLite目前最新的版本为3.5.7,在其他程序中使用SQLite时,需要SQLite的引擎文件sqlite3.dll。可以通过如下网址下载SQLite:

解压后,得到 sqlite3.exe 这样一个可执行文件,我们在命令行进入到解压后的目录,然后运行 sqlite3.exe test.db,进入 sqlite3 管理界面,然后执行SQL语句:

create table Users (id integer, EmailAddress varchar(50), UserName varchar(50), Password varchar(50));

创建一个下面例子要用到的表,然后输入.exit 退出。将会有一个名为test.db的文件被创建。

该文件包含一个SQLite命令行式的客户端程序,可以用来创建和访问SQLite数据库。

解压该文件后,生成一个dll格式的SQLite引擎文件:sqlite3.dll

该页面列出了许多管理SQLite数据库的GUI程序,利用这些GUI程序,可以很方便、直观的创建和管理SQLite数据库。通过,一个SQLite数据库就是一个文件,如test.db,文件扩展名可以为任何值,一般为db或者db3。

要在.Net中使用SQLite,还需要一个针对SQLite的ADO.NET Provider,可以通过以下网站下载:

解压该文件会生成一个我们需要的文件:SQLite.NET.dll

4。在VS.NET 2005中练习一下

(1) 在VS.NET 2005中创建一个名为 NHibernateWithSQLite 的C#控制台工程。

(2)把以下文件复制到工程目录下:

Castle.DynamicProxy.dll
Iesi.Collections.dll
log4net.dll
NHibernate.dll
SQLite.NET.dll

sqlite3.dll
test.db

(3)将

Castle.DynamicProxy.dll
Iesi.Collections.dll
log4net.dll
NHibernate.dll
SQLite.NET.dll

添加为工程的引用。

(4)将 test.db 和 sqlite3.dll 添加到项目中。并且在文件属性中,将文件的“复制到输出目录”设置为“如果较新则复制”。

(5)修改Program.cs文件,将以下内容复制到Program.cs文件中:

using System;
using System.Diagnostics;
using log4net;
using NHibernate;
using NHibernate.Cfg;
using NHibernateWithSQLite;

namespace NHibernateWithSQLite
{

    class Program
    {

        private const string TestEmailAddress = "";
        private const string TestPassword = "password";
        private const string TestUserName = "username";

        static void Main(string[] args)
        {

            // ----------------------------------------
            // Step 1: log4net configuration (optional)
            // ----------------------------------------
            log4net.Config.XmlConfigurator.Configure();


            // ---------------------
            // Step 2: Configuration
            // ---------------------
            Configuration configuration = new Configuration();
            Console.WriteLine("Configure NHibernate...");
            configuration.Configure();
            Console.WriteLine("Loading mapping files in this executable...");
            configuration.AddAssembly(System.Reflection.Assembly.GetExecutingAssembly());


            // --------------------------------
            // Step 3: Create a Session Factory
            // --------------------------------
            ISessionFactory factory = configuration.BuildSessionFactory();


            // ---------------------
            // Test 1: Create a User
            // ---------------------

            int firstId;

            using (ISession session = factory.OpenSession())
            {

                Console.WriteLine("Saving a test User object to the database...");

                User user = new User();
                user.EmailAddress = TestEmailAddress;
                user.Password = TestPassword;
                user.UserName = TestUserName;

                session.Save(user);
                session.Flush();

                firstId = user.Id;

                Console.WriteLine("The User object was assigned an ID of " + firstId + "!");

                Debug.Assert(
                    firstId > 0, "The Id should have been returned.");
            }


            // ---------------------
            // Test 2: Load the User
            // ---------------------
            using (ISession session = factory.OpenSession())
            {

                Console.WriteLine("Attempting to reload User with ID " + firstId + "...");

                User user = session.Load(firstId);

                Debug.Assert(
                    user.Id == firstId,
                    "The wrong Id field was returned.");
               
                Debug.Assert(
                    user.EmailAddress == TestEmailAddress,
                    "The wrong EmailAddress was returned.");

                Debug.Assert(
                    user.Password == TestPassword,
                    "The wrong Password was returned.");

                Debug.Assert(
                    user.UserName == TestUserName,
                    "The wrong UserName was returned.");

                Console.WriteLine("The user was reloaded successfully!");

            }


            // -----------------------
            // Test 3: Delete the User
            // -----------------------
            using (ISession session = factory.OpenSession())
            {
                Console.WriteLine("Deleting the user...");
                User user = session.Load(firstId);
                session.Delete(user);

                try
                {
                    Console.WriteLine("Confirming the user record is deleted...");
                    User deletedUser = session.Get(firstId);
                    throw new InvalidOperationException("The load should not have succeeded.");
                }
                catch(ObjectDeletedException ex)
                {
                    Console.WriteLine(ex.Message);
                }

                session.Flush();
            }

            Console.WriteLine("Done. Press Enter to exit...");
            Console.ReadLine();

        }
    }
}

(6)在项目中添加一个User.cs文件,内容为:

using System;
using System.Collections.Generic;
using System.Text;

namespace NHibernateWithSQLite
{
    public class User
    {

        private int id;
        private string emailAddress;
        private string username;
        private string password;


        public virtual int Id
        {
            get
            {
                return this.id;
            }
            set
            {
                this.id = value;
            }
        }

        public virtual string EmailAddress
        {
            get
            {
                return this.emailAddress;
            }
            set
            {
                this.emailAddress = value;
            }
        }

        public virtual string Password
        {
            get
            {
                return this.password;
            }
            set
            {
                this.password = value;
            }
        }

        public virtual string UserName
        {
            get
            {
                return this.username;
            }
            set
            {
                this.username = value;
            }
        }

    }
}

(7)添加一个 User.hbm.xml文件,内容为:



   
     
   

   
   
   



  

(8)在文件属性中,将该文件的“生成操作”设置为“嵌入的资源”。

添加一个App.config文件,其内容为:




   

       type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
   
            type="NHibernate.Cfg.ConfigurationSectionHandler, NHibernate"/>


   
      true
      on_close
      NHibernate.Connection.DriverConnectionProvider
      NHibernate.Driver.SQLiteDriver
      Data Source=test.db;Version=3
      NHibernate.Dialect.SQLiteDialect
      true=1;false=0
   


          type="log4net.Appender.ConsoleAppender, log4net">
     
                value="%d{ABSOLUTE} %-5p %c{1}:%L - %m%n" />
     

   

   
     
     
     
       
     

   

   
     
     
     
   

该文件为配置文件,用来配置NHibernate如何连接数据库,以及log4net。

(9)编译并运行

(10)祝贺您的程序成功运行

阅读(1771) | 评论(0) | 转发(0) |
0

上一篇:C++的异常

下一篇:魔方

给主人留下些什么吧!~~