原文:在论坛中出现的比较难的sql问题:23(随机填充问题)


最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了。

所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路。

1、一段SQL的写法,求方法!

http://bbs.csdn.net/topics/390705441

select * from k11  有10條紀錄

files1  files2  files3  files4

AA        BB     CC       DD

ZZ        EE     TT       YY

NN        MM     GG       UU

另外一个表User 有99条记录,现在要随机在User这个表里面随机选3条记录

select top 3 NewID() as random,[UserId] from [User]

random          UserId

E81A4DBB ming

F31B3B6C ling

16574317 Ting

将User这个表上的UserId值结果平均分配到k11上面那个表上,最后結果顯示如下

files1  files2  files3  files4  UserId

A1        BB     CC       DD     ming

A2        EE     TT       YY     ling

A3        MM     GG       UU     ling

A4        XX     XX       XX     ming

A5        XX     XX       XX     ling

A6        XX     XX       XX     Ting

A7        XX     XX       XX     ming

A8        XX     XX       XX     ling

A9        XX     XX       XX     ling

A10       XX     XX       XX     ming

sql代码:


  1. create table k11(
  2. files1 varchar(10),
  3. files2 varchar(10),
  4. files3 varchar(10),
  5. files4 varchar(10),
  6. UserId varchar(10))
  7. insert into k11
  8. select 'A1', 'BB', 'CC', 'DD', 'ming' union all
  9. select 'A2', 'EE', 'TT', 'YY', 'ling' union all
  10. select 'A3', 'MM', 'GG', 'UU', 'Ting' union all
  11. select 'A4', 'XX', 'XX', 'XX', 'ming' union all
  12. select 'A5', 'XX', 'XX', 'XX', 'ling' union all
  13. select 'A6', 'XX', 'XX', 'XX', 'Ting' union all
  14. select 'A7', 'XX', 'XX', 'XX', 'ming' union all
  15. select 'A8', 'XX', 'XX', 'XX', 'ling' union all
  16. select 'A9', 'XX', 'XX', 'XX', 'Ting' union all
  17. select 'A10', 'XX', 'XX', 'XX', 'ming'
  18. create table [user]
  19. (
  20. UserId varchar(10)
  21. )
  22. insert into [user]
  23. select 'ming' union all
  24. select 'ling' union all
  25. select 'Ting'
  26. go
  27. ;with t
  28. as
  29. (
  30. select [UserId],
  31. ROW_NUMBER() over(order by newid()) as rownum
  32. from [User]
  33. ),
  34. tt
  35. as
  36. (
  37. select *,
  38. case when rownum1 %3 =0 then 3 else rownum1 %3 end as rownum
  39. from
  40. (
  41. select *,
  42. ROW_NUMBER() over(order by getdate()) as rownum1
  43. from k11
  44. )a
  45. )
  46. select tt.files1,tt.files2,tt.files3,tt.files4,t.UserId
  47. from tt
  48. left join t
  49. on tt.rownum = t.rownum
  50. and t.rownum <=3
  51. /*
  52. files1 files2 files3 files4 UserId
  53. A1 BB CC DD ming
  54. A2 EE TT YY ling
  55. A3 MM GG UU Ting
  56. A4 XX XX XX ming
  57. A5 XX XX XX ling
  58. A6 XX XX XX Ting
  59. A7 XX XX XX ming
  60. A8 XX XX XX ling
  61. A9 XX XX XX Ting
  62. A10 XX XX XX ming
  63. */

2、随机返回100条数据:

如果表比较大,有上千万的数据,那么通过如下的代码,可以随机返回100条数据,这里的随机,不是真正意义上的随机,但确实能让人感觉是随机,也就是每次返回的数据都不一样,最关键的是速度非常快,接近于0秒,只消耗了 62毫秒。


  1. select *
  2. from
  3. (
  4. select *,
  5. ROW_NUMBER() over(order by @@servername) as rownum
  6. from dbo.xxx
  7. )t
  8. where rownum between CHECKSUM(getdate()) % 10000 and CHECKSUM(getdate()) % 10000+99
SQL Server 分析和编译时间:
CPU 时间 = 0 毫秒,占用时间 = 0 毫秒。 (100 行受影响) SQL Server 执行时间:
CPU 时间 = 0 毫秒,占用时间 = 62 毫秒。

发布了416 篇原创文章 · 获赞 135 · 访问量 94万+

在论坛中出现的比较难的sql问题:23(随机填充问题)的更多相关文章

  1. 在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题)

    原文:在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...

  2. 在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时、分钟计算问题)

    原文:在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时.分钟计算问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. ...

  3. 在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据)

    原文:在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决 ...

  4. 在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列)

    原文:在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

  5. 在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字)

    原文:在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

  6. 在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存)

    原文:在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...

  7. 在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题)

    原文:在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉 ...

  8. 在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题)

    原文:在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得 ...

  9. 在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名)

    原文:在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

  10. 在论坛中出现的比较难的sql问题:36(动态行转列 解析json格式字符串)

    原文:在论坛中出现的比较难的sql问题:36(动态行转列 解析json格式字符串) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

随机推荐

  1. numpy中的mean()函数

    本文链接:https://blog.csdn.net/lilong117194/article/details/78397329mean() 函数定义:numpy.mean(a, axis, dtyp ...

  2. git commit之后,撤销 commit

    写完代码后,我们一般这样 git add . //添加所有文件 git commit -m "本功能全部完成" 执行完commit后,想撤回commit,怎么办? 可以执行如下命令 ...

  3. shell编程系列2--字符串的处理

    shell编程系列2--字符串的处理 字符串的处理 .计算字符串的长度 方法1 ${#string} 方法2 expr length "$string" (如果string中间有空 ...

  4. RestSHarp

    异步扩展: public static class RestClientExtensions { private static Task<T> SelectAsync<T>(t ...

  5. 003-结构型-05-桥接模式(Bridge)

    一.概述 将抽象部分与它的具体实现部分分离.使它们都可以独立地变化.通过组合的方式建立两个类之间联系,而不是继承. Bridge 模式又叫做桥接模式,是构造型的设计模式之一.Bridge模式基于类的最 ...

  6. django中同通过getlist() 接收页面form的post数组

    前端中的一些东西: <form action="people?action=edit" method="post"> <input type= ...

  7. 【Leetcode_easy】914. X of a Kind in a Deck of Cards

    problem 914. X of a Kind in a Deck of Cards 题意:每个数字对应的数目可以均分为多组含有K个相同数目该数字的数组. 思路:使用 map 结构记录数组中每个元素 ...

  8. app--Android 稳定性测试方案

    标准的崩溃日志:Android 应用一般使用 Java 语言开发,在不作特殊处理的情况下,遇到未处理的异常时,会弹框提示“程序遇到异常,即将退出”(有些手机框中提示语不同, 或不弹框).同时会将异常的 ...

  9. 代码内存泄露检测(1) MLeaksFinder (Wechat开源) + FBRetainCycleDetector (FaceBook开源)

    每次项目编译完成之后,都被内存搞得头昏脑胀,压力甚大. 利用两周时间,稍微研究了 微信开源的 MLeaksFinder 和 facebook 开源的 FBMemoryProfiler, 这两个开源三方 ...

  10. 【Tools】PDF编辑软件-pdfelement 6.8 官网文件中文+破解版本

    试用了下,感觉还不错分享给大家. 有币的求赏,小弟下载缺币.没币的从附件下载. 赏币地址:https://download.csdn.net/download/qq_18187161/10744059 ...