WebForm分页浏览
//封装类
using System;
using System.Collections.Generic;
using System.Web; /// <summary>
/// Users 的摘要说明
/// </summary>
public class Users
{ private string _UserName; public string UserName
{
get { return _UserName; }
set { _UserName = value; }
}
private string _Password; public string Password
{
get { return _Password; }
set { _Password = value; }
}
private string _NickName; public string NickName
{
get { return _NickName; }
set { _NickName = value; }
}
private bool _Sex; public bool Sex
{
get { return _Sex; }
set { _Sex = value; }
}
public string SecStr
{
get { return _Sex ? "男" : "女"; }
}
private DateTime _Birthday; public DateTime Birthday
{
get { return _Birthday; }
set { _Birthday = value; }
}
public string BirthdayStr
{
get { return _Birthday.ToString("yyyy年MM月dd日"); }
}
private string _Nation; public string Nation
{
get { return _Nation; }
set { _Nation = value; }
} }
2连接数据库,建立方法
using System;
using System.Collections.Generic;
using System.Web;
using System.Data.SqlClient; /// <summary>
/// UserData 的摘要说明
/// </summary>
public class UserData
{
SqlConnection cnn = null;
SqlCommand cmd = null; public UserData()
{
cnn = new SqlConnection("server=.;database=ren;User=sa;pwd=123");
cmd = cnn.CreateCommand();
}
/// <summary>
/// 查询数据库所有内容
/// </summary>
/// <returns>泛型集合</returns>
public List<Users> quan()
{
List<Users> ulist = new List<Users>();
cmd.CommandText = "select * from Users";
cnn.Open();
SqlDataReader ss = cmd.ExecuteReader();
while(ss.Read())
{
Users u = new Users();
u.UserName = ss[].ToString();
u.Password = ss[].ToString();
u.NickName = ss[].ToString();
u.Sex = Convert.ToBoolean(ss[]);
u.Birthday = Convert.ToDateTime(ss[]);
u.Nation = ss[].ToString();
ulist.Add(u);
}
cnn.Close();
return ulist;
}
/// <summary>
///
/// </summary>
/// <param name="dijiye">第几页</param>
/// <param name="perpagenum">每一页的数量</param>
/// <returns></returns>
public List<Users> select(int dijiye,int perpagenum)
{
List<Users> ulist = null;
cmd.CommandText = " select top " + perpagenum + " * from Users where UserName not in(select top " + (perpagenum*(dijiye - )) + " UserName from Users)";
cnn.Open();
SqlDataReader ss = cmd.ExecuteReader();
if (ss.HasRows)
{
ulist = new List<Users>();
while (ss.Read())
{
Users u = new Users();
u.UserName = ss[].ToString();
u.Password = ss[].ToString();
u.NickName = ss[].ToString();
u.Sex = Convert.ToBoolean(ss[]);
u.Birthday = Convert.ToDateTime(ss[]);
u.Nation = ss[].ToString();
ulist.Add(u);
}
}
cnn.Close();
return ulist;
}
/// <summary>
/// 根据SQl语句,查询符合条件的数据
/// </summary>
/// <param name="sql">SQl查询条件</param>
/// <returns></returns>
public List<Users> zuhe(string sql)
{
List<Users> ulist = new List<Users>();
cmd.CommandText =sql;
cnn.Open();
SqlDataReader ss = cmd.ExecuteReader();
while (ss.Read())
{
Users u = new Users();
u.UserName = ss[].ToString();
u.Password = ss[].ToString();
u.NickName = ss[].ToString();
u.Sex = Convert.ToBoolean(ss[]);
u.Birthday = Convert.ToDateTime(ss[]);
u.Nation = ss[].ToString();
ulist.Add(u);
}
cnn.Close();
return ulist;
} }
3.页面设置
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default1.aspx.cs" Inherits="Default1" %> <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
</head>
<body>
<form id="form1" runat="server">
<asp:Repeater ID="Repeater1" runat="server">
<HeaderTemplate>
<table style="background-color:blue; width:100%">
<tr style="background-color:yellow;">
<td>姓名</td>
<td>密码</td>
<td>昵称</td>
<td>性别</td>
<td>生日</td>
<td>民族</td>
</tr> </HeaderTemplate>
<ItemTemplate>
<tr style="background-color:gray;">
<td><%#Eval("Username") %></td>
<td><%#Eval("Password") %></td>
<td><%#Eval("NickName") %></td>
<td><%#Eval("Sex") %></td>
<td><%#Eval("Birthday") %></td>
<td><%#Eval("Nation") %></td>
</tr> </ItemTemplate>
<FooterTemplate>
</table>
</FooterTemplate> </asp:Repeater>
当前第<asp:Label ID="dijiye" runat="server" Text="Label"></asp:Label>页,共<asp:Label ID="gongjiye" runat="server" Text="Label"></asp:Label>页 <asp:LinkButton ID="shangyiye" runat="server">上一页</asp:LinkButton>
<asp:LinkButton ID="xiayiye_button" runat="server">下一页</asp:LinkButton>  跳转到<asp:DropDownList AutoPostBack="true" ID="DropDownList1" runat="server"></asp:DropDownList>页
</form>
</body>
</html>
4、设置事件
using System;
using System.Collections.Generic;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls; public partial class Default1 : System.Web.UI.Page
{
int pagecount = ;//规定每页的数量
protected void Page_Load(object sender, EventArgs e)
{
gongjiye.Text = maxpage().ToString();
//gongjiye.Text = new UserData().select(1, pagecount).Count.ToString();
shangyiye.Click += shangyiye_Click;//上一页的点击事件
xiayiye_button.Click += xiayiye_button_Click;//下一页点击事件
DropDownList1.SelectedIndexChanged += DropDownList1_SelectedIndexChanged;//索引变化事件
if (!IsPostBack)
{
Repeater1.DataSource = new UserData().select(,pagecount);//第一页显示
Repeater1.DataBind();
dijiye.Text = "";//页面开始运行就是第一页 for (int i = ; i <= maxpage(); i++)
{
DropDownList1.Items.Add(new ListItem(i.ToString(), i.ToString()));//跳转按钮DropDownList1的页数添加
} }
} void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)//索引变化事件
{
int n = int.Parse(DropDownList1.SelectedValue);//取出选中哪一页
Repeater1.DataSource = new UserData().select(n,pagecount);//显示所选页数的内容
Repeater1.DataBind();//数据绑定
dijiye.Text = n.ToString();
} void xiayiye_button_Click(object sender, EventArgs e)//下一页点击事件
{
int xia = int.Parse(dijiye.Text) + ;
if (xia > maxpage())//下一页如果大于最大页
{
return;
}
Repeater1.DataSource = new UserData().select(xia,pagecount);
Repeater1.DataBind();
dijiye.Text = xia.ToString(); } void shangyiye_Click(object sender, EventArgs e)//上一页的点击事件
{
int shang = int.Parse(dijiye.Text)-;
if (shang == )
{
return;
}
Repeater1.DataSource = new UserData().select(shang, pagecount);
Repeater1.DataBind();
dijiye.Text = shang.ToString(); } public int maxpage()//求最多有多少页
{
int i;
List<Users> ulist = new UserData().quan();
if (ulist == null)
{
i = ;
}
else
{
i = int.Parse(Math.Ceiling(ulist.Count/(pagecount*1.0)).ToString());
}
return i;
} }
总之:就是拼Sql查询语句:
每页5行数据
select top 5 * from Users where UserName not in(select top 0 UserName from Users);显示第一页信息
select top 5 * from Users where UserName not in(select top 5 UserName from Users);显示第二页信息
以此类推。。。。。。。
select top " + perpagenum + " * from Users where UserName not in(select top " + (perpagenum*(dijiye - 1)) + " UserName from Users)
完!!!
.
WebForm分页浏览的更多相关文章
- PHP搜索MYSQL数据库加分页浏览小结
PHP搜索加分页浏览小结: 1 分页后再做搜索 2 这里对于url的拼接,以及模糊查询,搜索时候的显示添加,SQL语句的拼接 3 对于页面传递过来的超级链接的变量,如果不存在就要设置,对于可能抛出异常 ...
- iOS- UIScrollView、UIPageControl分页浏览图片
1.先介绍下UIScrollView的常见属性 @property(nonatomic) CGPoint contentOffset; // 记录UIScrollView滚动的位置 @property ...
- WebForm 分页、组合查询--2017年1月5日
sql = "select * from Commodity"; hs = new Hashtable(); if (txt_name.Text.Trim() != "& ...
- webform 分页、组合查询综合使用
界面: <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx ...
- WebForm 分页与组合查询
1.封装实体类 2.写查询方法 //SubjectData类 public List<Subject> Select(string name) { List<Subject> ...
- Android: 分页浏览的利器 android View Pager
最近有一个项目需求,水平滑动实现视图切换(分页显示效果) 最先想到的是ImageSwitcher + ViewFilpper 来实现,这效果做出来我自己都不想用,更不用说客户的感觉了:滑动效果生硬,只 ...
- 解决分页浏览后搜索无数据的问题(VUE+element-ui)
开发过程中发现了:浏览到第二页后.对数据进行查询时,后台返回的数据是空.原因是:当前页码为第二页.所以向后台发送请求的pageNumber=2,当pageNumber=1时.就可以查询到数据了. 所以 ...
- webform 分页
界面: <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx ...
- webform分页
前端界面: 当前第[<asp:Label ID="Label_nowpage" runat="server" Text="Label" ...
随机推荐
- [原创]java WEB学习笔记83:Hibernate学习之路---双向 1-n介绍,关键点解释,代码实现,set属性介绍(inverse,cascade ,order-by )
本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...
- ASP.NET状态管理策略
如果要想把信息存储在客户端那可以选择视图状态.控件状态.隐藏字段.cookie.和查询字符串. 1.web窗体页提供viewstate属性作为内置结构,在同一页的多个请求间自动保留值.他作为页面的隐藏 ...
- exec 临时表,报错
因为零时表只存在于一个exec 会话中,所以可以用 多个 select 返回到 dataset 中处理多个table,按照select 的顺序,读取 tables[0],table[1] , 多用于统 ...
- C#委托实例
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace we ...
- c#如实现将一个数字转化为其他进制字符串输出
之前在 os 上看到有人说过 一直想整理 但是一直没时间 后来 从csdn 上 知道了一份 下面内容 来自 (1)http://bbs.csdn.net/topics/60512816 tost ...
- YbRapidSolution.MVC项目首页缓存没有起作用
Response.Cache.SetOmitVaryStar(true); 文件方面的内容,增加了这个语句 没有的话缓存没起作用,增加这个语句可提高系统性能. HomeController: usin ...
- 10---Net基础加强
复习: using System; using System.Collections.Generic; using System.Linq; using System.Text; using Syst ...
- sql 修改字段长度以及其他属性
修改字段长度 语法 :alter table <表名> alter column <字段名> 新类型名(长度) alter table LoaneeExpand alt ...
- Multi-voltage和power gating的实现
power domain:一个逻辑的集合体,包含power supply的一些信息.建立在FE. voltage area:chip上的一块物理区域.可以看作power domain的物理实现. Le ...
- beta-1阶段各组员的贡献分分配
小组名称:nice! 小组成员:李权 于淼 刘芳芳 韩媛媛 宫丽君 项目内容:约跑app 分数分配规则 个人贡献分=基本贡献分*0.2+特殊贡献分*0.3+个人代码贡献量*0.5 其中 基本贡献分,特 ...