NHibernate使用入门(一)

项目结构如图:

这里写图片描述

Product.cs模型类

 public class Product
    {
        public virtual Guid Id { get; set; }
        public virtual string Name { get; set; }
        public virtual string Category { get; set; }
        public virtual int Price { get; set; }

    }

实体映射文件Product.hbm.xml

<?xml version="1.0" encoding="utf-8" ?>
    <hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
                       assembly="NHExample"
                       namespace="NHExample.Domain">

      <class name="Product" table="products">
    <id name="Id">
      <generator class="guid" />
    </id>
    <property name="Name" />
    <property name="Category" />
    <property name="Price" />
      </class>
    </hibernate-mapping>

全局配置文件hibernate.cfg.xml

 <?xml version="1.0" encoding="utf-8"?>
    <hibernate-configuration xmlns="urn:nhibernate-configuration-2.2">
    <session-factory>
        <property name="connection.driver_class">NHibernate.Driver.SqlClientDriver</property>
        <property name="connection.connection_string">Data Source=.\SQLINSTANCE;Initial Catalog=WhiskeyDemo;Persist Security Info=True;User ID=sa;Password=123456</property>
        <property name="dialect">NHibernate.Dialect.MsSql2008Dialect</property>

        <property name="query.substitutions">true=1;false=0</property>
        <property name="show_sql">true</property>
        <!--把NHibernate查询中的一些短语替换为SQL短语(比如说短语可能是函数或者字符)。例如: hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC-->
        <!--<mapping assembly="NHExample.Domain" />-->
    </session-factory>
    </hibernate-configuration>

Program.cs主程序代码

class Program
    {
        static void Main(string[] args)
        {

            //NHibernate的初始化
            var cfg = new Configuration();
            cfg.Configure();
            cfg.AddAssembly(typeof(Domain.Product).Assembly);

            // 得到一个自定义的Hibernate Session
            var sessions = cfg.BuildSessionFactory();
            var sess = sessions.OpenSession();

            // 创建数据库架构 
            new SchemaExport(cfg).Create(true, true);

            // 创建产品...
            var product = new Domain.Product
                        {
                            Name = "Some C# Book",
                            Price = 500,
                            Category = "Books"
                        };

            //并将其保存到数据库中
            sess.Save(product);
            sess.Flush();

            //请注意,我们在映射文件不使用指定表名,但类名,这是一个很好的抽象附带的NHibernate
            IQuery q = sess.CreateQuery("FROM Product");
            var list = q.List<Domain.Product>();

            // 列出所有条目的名字
            list.ToList().ForEach( p => Console.WriteLine( p.Name ));

            //不要马上关闭应用程序,这样我们就可以读取输出。
            Console.ReadLine();
        }
    }

运行结果如图:

这里写图片描述

生成的数据库

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值