科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道随机得到Access数据库记录

随机得到Access数据库记录

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

由于Access数据库记录集缓存的原因,从代码里得到Access数据库随机记录是得不到,需要用随机SQL语句的办法来消除缓存。

作者:中国IT实验室 来源:中国IT实验室 2007年9月5日

关键字: 数据库 Access 随机

  • 评论
  • 分享微博
  • 分享邮件
  由于Access数据库记录集缓存的原因,从代码里得到Access数据库随机记录是得不到,需要用随机SQL语句的办法来消除缓存。
  
  下面就是例子:
  
  查看例子http://dotnet.aspx.cc/Exam/GetRandom.aspx
  
  <%@ Page Language="C#" Debug="true" %>
  <%@ import Namespace="System.Data" %>
  <%@ import Namespace="System.Data.OleDb" %>
  <title>随机得到Access数据库记录</title>
  <script runat="server">
  void Page_Load(Object src,EventArgs e)
  {
  if(!IsPostBack)
   {
   string MyConnString = "Provider=Microsoft.Jet.OleDB.4.0;Data Source="
   + Server.MapPath("aspxWeb.mdb.ascx");
   Random R = new Random();
   int intRandomNumber = R.Next(1,1000);
  
   string sql = "select top 10 id As 序号,Title As 标题 from Document Order By Rnd("
   + (-1 * intRandomNumber).ToString() + "*id)";
   OleDbConnection MyConnection = new OleDbConnection(MyConnString);
   MyConnection.Open();
   OleDbCommand cmd = new OleDbCommand(sql,MyConnection);
   OleDbDataReader dr = cmd.ExecuteReader();
  
   DataGrid1.DataSource = dr;
   DataGrid1.DataBind();
   cmd.Dispose();
   MyConnection.Close();
   MyConnection.Dispose();
   MyConnection = null;
   }
  }
  
  </script>
  <form runat=server>
  <asp:DataGrid id="DataGrid1" HorizontalAlign="Center"
   Width="600px" runat="server" Font-Size="9pt">
   <AlternatingItemStyle BackColor="#EEEEEE"></AlternatingItemStyle>
   <HeaderStyle BackColor="#AAAADD" Font-Bold="True" HorizontalAlign="Center" />
  </asp:DataGrid>
  </form>

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章