发布网友 发布时间:2022-04-23 04:01
共2个回答
热心网友 时间:2023-09-24 00:23
此需求的难点在于你的网站抽奖池号码需要跟印刷品上的号码完全一致,否则就会出现网站号码跟印刷品上的抽奖号码完全脱节,或者引起用户不满,或者让你大出血本。因此你需要首先把印刷品上的号码全部灌入网站数据库——如果你做得到的话
其余的事情就很轻松了,用RND产生一个指定范围内的随机数,在SQL里用随机数为条件进行检索,当然每次用户不幸中奖以后要记得给该号码做一个标记,以后不参与检索,否则同一个中奖号码会出现N次(这就是随机数的特点),你哭都来不及。另外每次使用RND产生随机数要记得randomize ,否则后果也很难看
如果你确信网站的访问量会很高,同时抽奖号码的规模不大,比如几百个号码,那么我建议你在网站首次被访问的时候在数据库中提取抽奖号码灌入数组,并保存到Application里面,RND产生的随机数作为数组下标,用户不幸中奖的时候把该号码在数组中删除。对于任何计算机语言来说,通过数组下标访问数据都是速度最快代价最低的。不过Application在服务重启之后会清空,所以要定时用Application中数组的数据同步数据库,清除已经被用户抽中的号码。这种方式在大负荷WEB应用上能非常有效的降低数据库操作的压力。当然如果抽奖号码规模非常大就不适合数组方式了,老老实实用数据库比较好
热心网友 时间:2023-09-24 00:23
你用随机生成来做,也可以直接在sql语句实现。具体你查一下。