0

我正在尝试制作一个 C# 程序,该程序将通过单击一个按钮从我的 ms 访问数据库中选择一个随机数据.. 错误表明Data type mismatch in criteria expression.来自我创建的 OleDbDataReader..

这是我目前实现的。答案将不胜感激。

    {

        OleDbConnection connection = new OleDbConnection();

        connection.ConnectionString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\Users\miguel\Documents\QuotesGenFunny.accdb;
        Persist Security Info=False;";

        connection.Open();

        OleDbCommand command = new OleDbCommand();

        command.Connection = connection;
        command.CommandText = "SELECT TOP 1 * FROM Funny ORDER BY Rnd(-10000000*TimeValue(Now())*[Author])";

        OleDbDataReader reader = command.ExecuteReader();

        while (reader.Read())
        {
            listBox1.Items.Add(reader["Author"].ToString());
        }

        connection.Close();
    }
4

2 回答 2

0

如何从 MS Access 数据库中获取随机记录

检查评论。在您的情况下,正确的语法似乎是

ORDER BY Rnd(-(10000000*Funny)*Time())
于 2013-12-20T18:06:09.760 回答
0

您似乎正在尝试按随机值对记录进行排序,我认为这没有任何意义。

也许跳过随机数量的记录会更容易(只要确保它小于记录总数),然后再获取下一条记录。

如果您的记录的 ID 是一个加 1 的数字,您可能只需通过使用 C# 生成介于 0 和帖子总数 nr 之间的随机数来选择一个随机记录。

于 2013-10-15T06:52:21.583 回答