(再续).net分页控件webdiyer:aspnetpager与gridview联用

本文介绍了将.NET应用程序中的SQL查询转换为存储过程以实现分页功能的过程。内容包括SQL优化,存储过程的编写,以及在GridView和aspnetpager控件中的应用。在存储过程中,探讨了返回结果集的不同方式,并分享了实际操作中遇到的问题和解决方案,如避免使用'single quotes',以及调整分页查询逻辑以确保正确显示搜索结果。
摘要由CSDN通过智能技术生成

本篇是订单管理的第三篇,此次将原来的sql语句改成存储过程,后台只负责输入几个参数就可以了。想法很天真啊,原来以为直接把sql语句简单放过去就可以了,但好多细节没有考虑清楚,比如日常总结问题(7)中的存储过程里如果使用‘(单引号),这些原来都没有考虑。

分布梳理下这个改造成存储过程的过程

一、SQL优化

  原来的sql语句里将套餐信息和其他信息一起搜索出来,觉得会影响查询质量,于是改成了下面的语句

SELECT price,quantity,total,status,remark ,w1.orderid,w1.receiver1, shopconect
 FROM sales w1,
 ( SELECT TOP 20 row_number() OVER (ORDER BY orderid DESC) n, orderid,
 '国家:'+w3.country+',套餐天数:'+CAST( w3.days as varchar)+',套餐内容:'+w3.simcontent+',充值参加价:'
 +CAST( w3.simprice as varchar)+'RMB' as shopconect 
  from simshop w3,sales 
  where sales.orderflag=0 and sales.simid=w3.simID    ) w2 
   WHERE w1.orderid = w2.orderid  AND w2.n >0
其中w2.n>0的0是页码,top 20的20是每张页的大小,这个就是每20个数据为一页的第一页的数据,20=paindex+pa,n>paindex

     

 	int pa = AspNetPager1.PageSize;
 	int paindex = pa * (index - 1);


这样就可以达到第几页数据了

PS:在优化的时候,百度到一个sql语句,参考http://www.jb51.net/article/35213.htm(当时是为了编写存储过程,因为下面的sql语句有一个模板的存储过程,所以看了看)

SELECT * FROM ARTICLE w1 
    WHERE ID in 
        (
            SELECT top 30 ID FROM 
            (
                SELECT top 1030 ID, YEAR FROM ARTICLE ORDER BY YEAR DESC, ID DESC
            ) w ORDER BY w.YEAR ASC, w.ID ASC
        ) 
    ORDER BY w1.YEAR DESC, w1.ID DESC
原来也是想改成这个语句的,条件都适配好了,结果发现它是查出第1030的前30的,如果我想查出第二页的30个数据,我不会了,希望有看到这个的大神们帮忙解决下,我一看&
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
再次声明 千万不要把XiaoQi.dll 跟 XiaoQi.XML 给分开 2013年3月8号 修复了很多bug 调整了源代码 添加的时候 一定要引用 不要直接复制DLL 不然没有方法注释 最强大分分页控件 华丽的分页控件 实用的分页控件 有最新最实用的方法 联系小柒 下面是 AspNetHelp 类 方法概述 ///Show()弹出对话框 ///重载Show()弹出对话框 并且跳转界面 ///ShowJavascript()执行javascript脚本 ///FileDelete()给出文件虚拟路径删除文件 ///FileSize()获取上传文件大小 ///FileUpload()文件上传 路径upload/ 自动重命名 ///FileDownload()文件下载 调用方法如 FileDownload(Response,Server,文件虚拟路径) ///FileTxtWrite()写入TXT文本 给出要创建Txt 文本的地址 ///FileTxtReader()读取TXT文本 Txt 文本的地址 返回一个数组 每一行为数组里的一个元素 ///StringEncrypt() DES字符串加密中文不可以加密 ///StringDecrypt()DES解密字符串 ///StringMD5Encrypt()MD5加密 ///StringPYChar()单个汉字返回该汉字首字母 ///StringRandom()生成指定位数的随机数 ///StringEdit()给出指定字符串长度多少位后用点显示... ///StringReplaceSpace()替换文本中的空格和换行 ///StringColor()改变字的颜色 ///StringNull()当对象是空的时候 转为空字符串 ///StringConvert()汉字转拼音 ///StringNumber()数字转换中文 ///StringRep()url参数为中文时候转换加密 ///StringRes()url参数为中文时候转换解密 ///ShowWindowForm()弹出新窗口面 ///ShowFormModalDialog()弹出模式窗口面 ///SqlGetMaxID()给出表名列名 int类型 查询出最大列值+1 适用于主键 ///SqlGetSingle()执行一条计算查询结果语句,返回查询结果(object)。 ///SqlExecute()执行SQL语句,返回影响的记录数 ///SqlRunStr()执行SQL语句,不返回影响的记录数 ///SqlRunReturn()执行SQL语句,并返回第一行第一列结果 ///SqlGetReader()获得SqlDataReader对象 使用完须关闭DataReader,关闭数据库连接 ///SqlGetTable()执行查询语句,返回DataTable ///SqlDataSet()执行查询语句,返回DataSet ///SqlIsCunZai()执行Sql 语句查询是否有数据 如果没有返回假 ///SqlRunProc()执行存储过程 ///DataBindDropDownListDefault()DropDownList控件绑定 带默认选择项 如"请选择" ///DataBindDropDownList()DropDownList控件绑定 不带默认选择项 ///DataBindRadioButtonList()RadioButtonList控件绑定 默认第一个选中 ///DataBindCheckBoxList()CheckBoxList控件绑定 ///ElseIpAddr()调用此方法 返回当前登录的省市IP地址 ///ElseDataTimeIng()返回本地电脑的当前日期的年月日时分秒 动态的显示 JS实现 ///ElsePageLoad()面加载数据加载完成呈现面 ///ElseCkeck()返回面验证码图片 使用方法:单独创建一个面 在首次加载事件里写 AspNetHelp.ElseCkeck(Page); 在使用验证码的面直接写 img src="这个面的路径" 注意验证码保存在 Session["CheckCode"]中 这里是区分大小写的 ///ElseColorRGB()由于QQ截图的取色会出现RGB的颜色 这里能转换成16进制 分页控件详情请看内置文档
这个分页控件,修改连接字符串,和SQL语句,就可以了。 剩下的直接粘贴进去。就行。 强大的各种属性,附带多种CSS,想怎么分就怎么分页! 拖入工具箱后实现 1.2.3步(你修改下连接符,表就可以了) 控件.aspx面 复制粘贴到前台面适当位置即可 <webdiyer:AspNetPager ID="Pager1" runat="server" pagesize="9" CssClass="anpager" onpagechanged="AspNetPager1_PageChanged" FirstPageText="首" LastPageText="尾" NextPageText="下一" PrevPageText="上一" ShowPageIndexBox="Never"></webdiyer:AspNetPager> 控件.cs面,后台面 只需3步 设置连接字符串 string connstring = "Data Source=.;Initial Catalog=数据库名;User ID=用户名;Password=密码"; 程序面内容:复制粘贴修改几个 //首加载-1 protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { SqlConnection conn = null; try { conn = new SqlConnection(connstring); conn.Open(); SqlCommand Count = new SqlCommand(); Count.Connection = conn; //修改你们查询的表 Count.CommandText = "select count(*) from products"; //查询 Pager1.RecordCount = (int)Count.ExecuteScalar(); //Pager1为分页控件ID BindData(); } finally { conn.Close(); } } } //绑定数据-2 public void BindData() { SqlConnection conn = new SqlConnection(connstring); string sql = "select * from products";//修改你们的查询语句: //select top查询语句 SqlDataAdapter da = new SqlDataAdapter(sql, conn); DataSet ds = new DataSet(); da.Fill(ds, Pager1.PageSize * (Pager1.CurrentPageIndex - 1), Pager1.PageSize, "temptbl"); DataTable dt = ds.Tables["temptbl"]; DataList1.DataSource = dt; DataList1.DataBind(); } //控件事件-每次重新绑定 protected void AspNetPager1_PageChanged(object src, EventArgs e) { BindData(); }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值