还是查询的问题

gltgl 2003-10-09 06:23:11
根据条件查询,我把查询输入条件和查询结果放在了一个页面上。可以有查询结果了,但是现在有个新问题:
在得到查询结果以后,如果我进行了翻页,然后在输入新条件,会有以下提示:
无效的 CurrentPageIndex 值。它必须大于等于 0 且小于 PageCount。
我该在什么地方设置,让CurrentPageIndex值在点击按钮的时候自动设置成1呢?
源代码:
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
If Not IsPostBack Then
SetVirtualItemCount()
End If
End Sub

Private Sub LinkButton1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles LinkButton1.Click
Response.Redirect("htmlpage1.htm")
End Sub

Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click


Dim strSQL As String
Dim Strbt = Trim(txtBT.Text)
Dim Strnr = Trim(txtNR.Text)

If Strnr = "" And Strbt = "" Then
strSQL = "select * from files order by id desc"
ElseIf Strbt = "" Then
strSQL = "select * from files where texts like '%" & Strnr & "%' order by id desc"
ElseIf Strnr = "" Then
strSQL = "select * from files where topic like '%" & Strbt & "%' order by id desc"
Else
strSQL = " select * from files where topic like '%" & Strbt & "%' and texts like '%" & Strnr & "%' order by id desc"
End If
Label5.Text = strSQL

SetVirtualItemCount()
DataFiller()

End Sub

Sub DataFiller()
'只要翻页,重新输入查询条件就会出错!
Dim StrConn As String = ConfigurationSettings.AppSettings("DataConn")
Dim objConn As New SqlConnection(StrConn)
objConn.Open()

Dim strSQL As String = Label5.Text

Dim objAdapter As New SqlDataAdapter(strSQL, objConn)

Dim objDataSet As New DataSet()
objAdapter.Fill(objDataSet, "topic")

MyGrid.DataSource = objDataSet.Tables.Item("topic")
MyGrid.DataBind()
End Sub

Sub GridPageChange(ByVal S As Object, ByVal E As DataGridPageChangedEventArgs)
MyGrid.CurrentPageIndex = E.NewPageIndex
DataFiller()
End Sub

Sub SetVirtualItemCount()
' Set up the connection
Dim strConn As String = ConfigurationSettings.AppSettings("DataConn")
Dim conn As New SqlConnection(strConn)

' Set up the command
Dim strCmd As String = "SELECT COUNT(*) FROM files"
Dim cmd As SqlCommand = New SqlCommand(strCmd, conn)

' Execute the command
conn.Open()
Dim nItemCount As Int32 = cmd.ExecuteScalar()
conn.Close()

MyGrid.VirtualItemCount = nItemCount
End Sub
...全文
30 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
gltgl 2003-10-10
  • 打赏
  • 举报
回复
我添加了一句:
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click


Dim strSQL As String
Dim Strbt = Trim(txtBT.Text)
Dim Strnr = Trim(txtNR.Text)

If Strnr = "" And Strbt = "" Then
strSQL = "select * from files order by id desc"
ElseIf Strbt = "" Then
strSQL = "select * from files where texts like '%" & Strnr & "%' order by id desc"
ElseIf Strnr = "" Then
strSQL = "select * from files where topic like '%" & Strbt & "%' order by id desc"
Else
strSQL = " select * from files where topic like '%" & Strbt & "%' and texts like '%" & Strnr & "%' order by id desc"
End If
Label5.Text = strSQL

mygrid.CurrentPageIndex=1
SetVirtualItemCount()
DataFiller()

End Sub
树猫 2003-10-09
  • 打赏
  • 举报
回复
设置 DataGrid的当前页索引 之前,先判断欲设置的索引是小于 DataGrid当前总页数-1,若是 将其设为1
Re: 《用户管理及用户信息查询命令》 ---------------------------------------内容提要: 01/19)命令useradd   :创建用户02/19)命令usermod :修改用户信息03/19)命令userdel    :删除用户04/19)命令groupadd:创建新组05/19)命令groupdel :删除用户组06/19)命令passwd    :修改用户密码07/19)命令chage      :修改用户密码有效期08/19)命令chpasswd:批量更新用户密码09/19)命令su            :切换用户10/19)命令visudo     :编辑sudoers文件11/19)命令sudo        :以另一个用户身份执行命令12/19)命令id             :显示用户与用户组的信息13/19)命令w             :显示已登录用户信息14/19)命令who          : 显示已登录用户信息15/19)命令users       :显示已登录用户16/19)命令whoami    : 显示当前登录的用户名17/19)命令last          :显示用户登录列表18/19)命令lastb         : 显示用户登录失败的记录19/19)命令lastlog      : 显示所有用户的最近登录记录  本人在教学和实战过程中发现,即便是有一定运维经验的人,可能已经能够搭建一定复杂度的Linux架构,但是在来来回回的具体操作中,还是体现出CLI(命令界面)功底不够扎实,甚至操作的非常‘拙’、处处露‘怯’。 对一个士兵来说,枪就是他的武器,对于一个程序员来说,各种library(工具库)就是他的武器;而对于Linux运维人员来说,无疑命令行工具CLI(命令界面)就是他们的武器;高手和小白之间的差距往往就体现在对于这些“武器”的掌握和熟练程度上。有时候一个参数就能够解决的事情,小白们可能要写一个复杂的Shell脚本才能搞定,这就是对CLI(命令界面)没有理解参悟透彻导致。 研磨每一个命令就是擦拭手中的作战武器,平时不保养不理解,等到作战的时候,一定不能够将手中的武器发挥到最好,所以我们要平心、静气和专注,甘坐冷板凳一段时间,才能练就一身非凡的内功! 本教程从实战出发,结合当下流行或最新的Linux(v6/7/8 版本)同时演示,将命令行结合到解决企业实战问题中来,体现出教学注重实战的务实精神,希望从事或未来从事运维的同学,能够认真仔细的学完Linux核心命令的整套课程。 本课程系列将逐步推出,看看我教学的进度和您学习的步伐,孰占鳌头! 注:关于教学环境搭建,可以参考本人其它课程系列,本教学中就不再赘述! 《参透 VMware 桌面级虚拟化》 《在虚拟机中安装模版机(包括应用软件等)》 《SecureCRT 连接 GNS3/Linux 的安全精密工具》 

62,041

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧