SQL中随机选取行

Mssql : SELECT TOP 10 OrderID, NewID() as Random FROM Orders ORDER BY Random 

关键在于NewID()这个函数,他生成一个随机数。

随机提取10条记录的例子:
SQL Server:Select Top 10 * From 表 Order By NewID()

Access:

            Random rnd = new Random(unchecked((int)DateTime.Now.Ticks));
            int intRandomNumber = rnd.Next();

            Select Top 10 * From 表 Order By Rnd(" + (-1 * intRandomNumber) + "*id)

MySql:Select * From 表 Order By Rand() Limit 10

oracle: Order By dbms_random.value;
1。Order By dbms_random.value ,为结果集的每一行计算一个随机数,dbms_random.value 是结果集的一个列(虽然这个列并不在select list 中),然后根据该列排序,得到的顺序自然就是随机的啦。
2。看看desc信息便知道vlue和random这两个函数的区别了,value返回的是number类型,并且返回的值介于1和0之间,而random返回的是BINARY_INTEGER类型(以二进制形式存储的数字,据说运算的效率高于number但我没测试过,但取值范围肯定小于number,具体限制得查资料了)
如果你要实现随机排序,还是用value函数吧


你可能感兴趣的:(oracle,sql,mysql,SQL Server,Access)