zoukankan      html  css  js  c++  java
  • Nhibernate分页测试续

    Nhibernate分页测试续(附源码)

    接着上一篇Nhibernate分页测试,最近一直在接触Nhibernate,接触的越多、了解越深,越是感觉他的强大,很多功能都封装的很好,对数据操作是那么的简单。接下来介绍的是MVC+Nhibernate分页的应用:

    1.配置

    复制代码
    <?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=.;Initial Catalog=NhibernateDemoDB;Persist Security Info=True;Integrated Security=SSPI;
        </property>
        <property name="adonet.batch_size">10</property>
        <property name="show_sql">true</property>
        <property name="dialect">NHibernate.Dialect.MsSql2005Dialect</property>
        <property name="use_outer_join">true</property>
        <property name="command_timeout">10</property>
        <property name="query.substitutions">true 1, false 0, yes 'Y', no 'N'</property>
        <property name="proxyfactory.factory_class">
          NHibernate.ByteCode.Castle.ProxyFactoryFactory,
          NHibernate.ByteCode.Castle
        </property>
        <mapping assembly="NhibernateDemo.Data"/>
      </session-factory>
    </hibernate-configuration>
    复制代码

     配置想必接触过Nhibernate的人或多或少都有所了解,在这就不多加说明了。

    2.映射

    传统对象和关系数据库之间的映射是用一个XML文档(XML document)来定义的,这个映射文档被设计为易读的,并且可以手工修改。而我更喜欢的是用Fluent Nhibernate一个开源的框架,有了它就可以脱离传统的Nhibernate配置文件配置映射文件的方式,而采用强类型方式映射。如下:

    复制代码
        public class CustomerMap:ClassMap<Customer>
        {
            public CustomerMap()
            {
                Id(m => m.Id);

                Map(m => m.Name);

                Map(m => m.Tel);

                Map(m => m.Address);

                Map(m => m.CreateDate);

                Map(m => m.Sex);
            }
        }
    复制代码

    3.创建ISession

    Nhibernate操作数据库要通过ISession(NHibernate的工作单元),框架Fluent Nhibernate下创建ISession可看Fluent NHibernate的初识。如下

    复制代码
        public class NHibernateHelper
        {
            private static Configuration configuration = null;
            private static ISessionFactory sessionFactory = null;

            public static void CreateConfiguration()
            {
                configuration = new Configuration().Configure();
            }

            public static Configuration Configuration
            {
                get
                {
                    if (configuration == null)
                    {
                        CreateConfiguration();
                    }
                    return configuration;
                }
                set { configuration = value; }
            }

            public static ISessionFactory SessionFactory
            {
                get
                {
                    if (sessionFactory == null)
                    {
                        if (Configuration == null)
                        {
                            CreateConfiguration();
                        }
                        FluentConfiguration fluentConfiguration = Fluently.Configure(Configuration);
                        string path = AppDomain.CurrentDomain.SetupInformation.ApplicationBase;
                        string assemblyFile = Path.Combine(path, "bin/NhibernateDemo.Data.dll");
                        fluentConfiguration.Mappings(delegate(MappingConfiguration m)
                        {
                            Assembly assembly = Assembly.LoadFrom(assemblyFile);
                            m.HbmMappings.AddFromAssembly(assembly);
                            m.FluentMappings.AddFromAssembly(assembly).Conventions.AddAssembly(assembly);
                        });
                        return fluentConfiguration.BuildSessionFactory();
                    }
                    else
                    {
                        return sessionFactory;
                    }
                }
            }

            public static ISession CreateSession()
            {
                return SessionFactory.OpenSession();
            }
            
        }
    复制代码

    CreateSession方法创建了一个ISession。

    4.分页方法

    复制代码
            /// <summary>
            /// 获取分页
             /// </summary>
            /// <param name="pageStart"></param>
            /// <param name="pageLimit"></param>
            /// <returns></returns>
            public IList<Customer> GetCustomerPageModel(int pageStart, int pageLimit)
            {
                //HQL查询
                IList<Customer> customerList = Session.CreateQuery("from Customer")
                    .SetFirstResult(pageStart * pageLimit)
                    .SetMaxResults(pageLimit)
                    .List<Customer>();
                return customerList;

                //条件查询
                //return Session.CreateCriteria(typeof(Customer))
                //    .SetProjection(Projections.ProjectionList()
                //    .Add(Projections.Property("Id"), "Id")
                //    .Add(Projections.Property("Name"), "Name")
                //    .Add(Projections.Property("Tel"), "Tel")
                //    .Add(Projections.Property("Address"), "Address")
                //    .Add(Projections.Property("Sex"), "Sex")
                //    .Add(Projections.Property("CreateDate"), "CreateDate"))
                //    .AddOrder(Order.Asc("Id"))
                //    .SetFirstResult(pageStart * pageLimit)
                //    .SetMaxResults(pageLimit)
                //    .SetResultTransformer(Transformers.AliasToBean(typeof(Customer)))
                //    .List<Customer>();

                //SQL查询
                //IList<Customer> customerList = Session.CreateSQLQuery("SELECT * FROM Customer")
                //    .SetFirstResult(pageStart*pageLimit)
                //    .SetMaxResults(pageLimit)
                //    .SetResultTransformer(Transformers.AliasToBean<Customer>()).List<Customer>(); 
                //return customerList;
            }
    复制代码

    在Nhibernate里实现分页用 SetFirstResult 和SetMaxResults实现,SetFirstResult 简单的理解就是从第几条记录开始,SetMaxResults是取几条记录。如上代码,列出了Nhibernate三种查询分页的方式,使用哪种方式就看个人爱好了。

    以下是运行后的截图:

    客户端采用JQuery.

    项目中碰到了用jQuery从后台获取的json格式的日期的字符串,需要将此字符串转换成JavaScript的日期对象,以下是网上找的解决方法:

    //转换json格式的日期(如:{ServerDatetime:"/Date(1278930470649)/"})转换为Javascript的日期对象
    function ConvertJSONDateToJSDateObject(JSONDateString) {
         var date = new Date(parseInt(JSONDateString.replace("/Date(", "").replace(")/", ""), 10));
         return date;           
    }

    源码:NhibernateDemo.rar

     
     

    当前标签: Nhibernate

     
    Nhibernate分页测试续(附源码) john chen 2011-01-03 02:48 阅读:1696 评论:0  
     
    Fluent NHibernate的初识 john chen 2010-12-21 18:37 阅读:965 评论:0  
     
    NHibernate分页的测试 john chen 2010-12-04 08:54 阅读:2320 评论:7  
  • 相关阅读:
    实验11——指针的基础应用
    C语言程序设计第10堂作业
    实验九——基本数据类型存储及应用总结
    C语言程序设计第8堂作业
    实验七——函数定义及调用总结
    实验六——循环结构程序练习总结
    实验五——循环结构学习总结
    实验四——多分支结构及本章总结
    9.29第三次作业
    zuoyeQAQ
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/3892177.html
Copyright © 2011-2022 走看看