频道直达 - 专题 - 新闻 - 技巧 - 组网 - 开发 - 安全 - web编程 - 图像 - 操作系统 - 数据库 - 教育 - 旅游 - 健康 - 时尚 - 驱动 - 软件 - 游戏 - 多媒体 - ERP - 讨论组

vb.net数据库获取随机数据记录

来源:qqread 作者:douces 出处:巧巧读书 2008-01-19 进入讨论组

以前使用vb6操作数据库的时候,可以使用ADODB 组件来与数据库建立连接,然后把一个数据表读入到一个RecordSet中,我们要获取随机的记录的时候可以使用如下代码来实现:

假设已经连接上了数据库,并打开了一个变量名为rsUser的RecordSet

Dim R As Random = New Random

Dim int As Integer = R.Next(1, rsUser.RecordCount)

rsUser.Move(int, 1)

vb.net中,我们使用ADO.net来操作数据库,一般获取一个随机记录,都是打开一个只读的DataReader,而它是按顺序读取记录的,所以我们不能用Move 方法跳到随机数所指向的记录,但是我们可以考虑直接在SQL语句中进行随机数查询。示例如下:

首先建立一个Windows项目,在Form1窗体级代码中添加OleDB 的引用:

Imports System.Data.OleDb

然后在一个按钮的Click事件中添加如下代码:

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

Dim objConn As OleDbConnection

Dim objCmd As New OleDbCommand

'这里假设你的机子上存在名为 dos.mdb 的数据库

objConn = New OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0; Data Source=" & Application.StartupPath & "\dos.mdb")

objConn.Open()

objCmd.Connection = objConn

'表示取id大于等于1到100的随机数,这样是防止碰到不存在的ID,100这个数值在实际使用中应该是等于数据库的最大记录ID

'http://www.qqread.com/book/myvbnet/my0053.html

objCmd.CommandText = "select top 1 * from info where id>=int(100*Rnd()+1)"

Dim objRd As OleDbDataReader = objCmd.ExecuteReader()

If objRd.HasRows = True Then

objRd.Read()

MessageBox.Show(objRd.GetValue(0).ToString)

Else

MessageBox.Show("没有找到记录")

End If

End Sub

收藏地址:http://www.qqread.com/book/myvbnet/my0053.html 更多文章 更多内容请看数据库专栏数据库处理专题城域网专题专题,或进入讨论组讨论。
收藏此文】【 】【打印】【关闭
相关图文阅读
频道图文推荐
健 康 咨 询
时 尚 咨 询
巧巧读书宗旨
相关专题
讨论组问题推荐
站内各频道最新更新文档
站内最新制作专题
热门关键字导读
Photoshop教 程照片处理 照片制作 PS快捷键 抠图
计 算 机 故 障XP系统修复
艺 术 与 设 计设计 流媒体 设计欣赏 边框
计 算 机 安 全ARP
站内频道文章精选
巧巧电脑频道编辑信箱  告诉我们您想看的专题或文章