zoukankan      html  css  js  c++  java
  • ASP.NET MVC and jqGrid 学习笔记 3-如何从数据库获得数据

    实际应用中,大部分都是从数据库里获得数据,所以先建立一个数据库,Database first 或者Code first都可以,这里用Code first。

    一、Model

       public class Member
        {
            [Key]
            public int No { get; set; }
    
            [Required]
            [MaxLength(5)]
            public string Name { get; set; }
    
            [MaxLength(200)]
            public string Email { get; set; }
    
            [DatabaseGenerated(DatabaseGeneratedOption.Computed)]
            public DateTime? CreatedOn { get; set; }
        }

    再创建一个数据上下文类:

    using System.Data.Entity;
    
    namespace HelloJqGrid.Models
    {
        public class MyContext:DbContext
        {
            public MyContext():base("name=DefaultConnection"){}
    
            public DbSet<Guestbook> Guestbooks { get; set; }
            public DbSet<Member> Members { get; set; }
        }
    }

    好了!按理说就是这样就算Model建好了。但是我们的数据库在哪里呢?摸索后发现,还必须得把它“激活”才能看得到。怎么激活?用刚创建的2个类来自动生成CRUD,然后添加一些数据,保存后,在App_Data文件夹里就看到了(点击显示所有文件,刷新)。

    生成CRUD的过程:

    新建一个Controller

    就是刚才创建的2个类。

    点击添加按钮后就自动生成了CRUD的页面。

    书归正传。

    二、View

    @{
        ViewBag.Title = "ShowServerData";
    }
    
    <h2>ShowServerData</h2>
    <script type="text/javascript">
        $(function () {
            jQuery("#grid").jqGrid({
                url: "/Home/GetServerData",
                datatype: "json",           
                mtype:"get",
                //colNames: ['No', 'Name', 'Client'],
                colModel: [
                    {label:'Number', name: 'No', index: 'No',  60, sorttype: "int" },
                    {label:'Name', name: 'Name', index: 'Name',  90 },
                    {label:'Email', name: 'Email', index: 'Email',  100 },
                    {label:'Created On', name: 'CreatedOn', index: 'CreatedOn',  100 }
                ],
                caption: "jqGrid data",
                rowNum: 5,
                pager: "pager",
                viewrecords: true,
                 500, height: "auto",
                jsonReader:{repeatitems: false}
            });
        });
    </script>
    
    <table id="grid"></table>
    <div id="pager"></div>

    三、Controller

    在Controller中写2个action,一个是显示页面的,一个是从数据库获得数据的。

         public ActionResult ShowServerData()
            {
                return View();
            }
            public ActionResult GetServerData(int? page, int? rows,string sidx,string sord)
            {
                HelloJqGrid.Models.MyContext db = new Models.MyContext();
                var query = db.Members.ToList();
    
                //jqgrid的参数
                int pageNum = page.HasValue ? page.Value : 1;//当前显示哪一页
                int pageSize = rows.HasValue ? rows.Value : 10;  //每一页显示多少条记录
                int totalRecords = query.Count();//总记录数
                int totalPages = (int)Math.Ceiling((float)totalRecords / (float)pageSize);//总页数
                var jsonData = new
                {
                    total = totalPages,
                    page = pageNum,
                    records = totalRecords,
                    rows = query.Skip((pageNum - 1) * pageSize).Take(pageSize)//分页
                };
    
                return Json(jsonData, JsonRequestBehavior.AllowGet);
            }

    其实和从本地获得数据代码差不多,只是用:

     HelloJqGrid.Models.MyContext db = new Models.MyContext();
     var query = db.Members.ToList();

    来作为rows的数据。

    完了。

    完了!对,Run 一下就显示数据了,但是!这个不能排序!

    说到排序,好像就一下子牵涉到了很多的东西,什么动态linq,表达式树等等。居然很复杂!下回再说。

  • 相关阅读:
    .NET WinForm下StatusStrip控件如何设置分隔线及部分子控件右对齐
    winform 弹出窗体指定位置
    命名空间“System.Web”中不存在类型或命名空间名称“Optimization”(是否缺少程序集引用?)
    SQL之case when then用法详解
    VS2015编译错误:调用的目标发生了异常--->此实现不是Windows平台FLPS验证的加密算法的一部分。
    .NET Core 控制台中文乱码问题!
    IOC 依赖注入 Unity
    《重构:改善代码的既有设计》读书笔记
    .NET中的堆(Heap)和栈(Stack)的本质
    浅谈 Sql Server 游标
  • 原文地址:https://www.cnblogs.com/ibgo/p/3481015.html
Copyright © 2011-2022 走看看