存档

文章标签 ‘SQL Server’

【SQL】随机读取N条记录(MySQL、SQL Server、Access、Oracle、postgreSQL)

2010年3月24日 2 条评论

利用一条SQL语句从数据库Table表中随机获取N条记录,各数据库的SQL语句略有不同,如下:

1、MySql

Select * From TABLE Order By Rand() Limit N

以上代码效率不高,自己对1000条数据表随机取10条的测试结果为耗时0.125s,有网友推荐改为以下代码效率有大幅提高,耗时为0.005s,不过结果是随机从某个位置开始取N条记录,而不是随机取N条记录,略有差异。详细说明见mysql使用rand随机查询记录效率测试

SELECT * FROM `TABLE` a join (SELECT ROUND(RAND() * ((SELECT MAX(id) FROM `TABLE`)-(SELECT MIN(id) FROM `TABLE`))+(SELECT MIN(id) FROM `TABLE`)) AS id) AS b WHERE a.id >= b.id ORDER BY a.id LIMIT N;

2、SQL Server

Select TOP N * From TABLE Order By NewID()

阅读全文…

分类: 程序开发 标签: , , , , , 3,618次阅读

SQL Server 2005“备份集中的数据库备份与现有的数据库不同”的解决方案

2009年10月28日 2 条评论

SQL Server 2005还原.bak的数据库备份,还原失败,提示“备份集中的数据库备份与现有的数据库不同”。

解决方法是选择好还原的数据源后,在还原界面做如下设置:

选项(Options)->还原选项(Restore options)->覆盖现有数据库(Overwrite the existing database)

之后点击确定导入即可。

分类: 软件技巧 标签: , 8,624次阅读