优秀的软件开发团队:深圳升蓝软件 数据库开发 .Net技术  |  ASP技术 PHP技术 JSP技术 应用技术类     
热门推荐
升蓝OA办公自动化系统
基于.Net技术的网络
协同办公环境
 
ASP基础
数据库相关
安全加密
全文检索
ASP应用
打印相关
客户端相关
XML相关
系统相关
正则表达式
ASP技巧
组件开发
脚本编码
FSO专题
邮件相关
远程脚本
性能优化
 
相关链接
深圳升蓝软件:系统集成、办公自动化平台、电子商务、电子政务、Web数据库、企业网站、游戏、手机应用程序、CDMA软件、电子出版物等,为客户提供优秀的解决方案
 
升蓝(www.hi-blue.com)为企业管理、政府办公提供成熟的、易于实施的IT技术服务,我们的解决方案包括OA办公自动化系统CRM客户关系管理系统ERP企业生产管理和订单管理系统电子政务系统、知识管理系统、企业门户、商业智能、工程项目管理等等...
 
电子政务解决方案
塑料/橡胶管理系统
知识管理系统简介
多媒体光盘方案
ERP企业资源管理
订单计划管理系统
PM工程项目管理系统
会员管理系统
相关资料下载
OA办公自动化系统
CRM客户关系管理系统
在线试用版本说明
OA 系统的用户手册
 
 
 
 
升蓝开发团队 > 技术资料 > ASP技术 > 客户端相关 : 利用随机函数获取某一范围的整数及其应用

利用随机函数获取某一范围的整数及其应用


March 25,2004
[“酷闪”原创]

我们在编写ASP的过程中经常会遇到需要取得一个整数范围内的一个随机整数,利用VBScript内建的Rnd()函数可以很轻松
的得到这样的整数,假如要从[min,max]这个整数范围内随机抽取一个整数,具体公式如下:

随机整数=Int((max-min+1)*Rnd()+min)

仔细思考一下上面的公式,应该很快能理解其中的含义。

下面就以“酷闪”首页“自助链接”为例,来说明随机抽取整数在数据库查询中的一个用途。

构想


“酷闪”首页提供自助连接,允许自行加入某网站连接。
一般的“自助连接”只是在首页显示最新加入的若干个连接,然后另外提供一个浏览所有连接的页面,很多情况下,只有
不多的浏览者去打开该页去查询以前加入的连接,这样就使得比较早加入的连接基本没有被点击的机会。根据这种情况采
取以下方案:在首页显示10个连接,其中前3个是最新加入的连接,后7个从以前加入的连接中随机抽取7个显示。

具体实现


用Access数据库保存用户信息(网站名称,网址,简要说明),建立add.asp(加入操作页面),
改造首页加入显示程序段。这里只对显示程序段给以说明。
假设Access数据库文件为link.mdb,并已经有超过20个的连接信息,其中自助连接信息放在表selflink中,包含字段:
ID,网站名称,地址,简要说明,加入时间

程序代码

'首页打开数据库,并将所有记录按时间倒序排列,新加入的在前
set con=server.CreateObject("adodb.connection")
con.open "Driver={Microsoft Access Driver (*.mdb)};DBQ="&Server.MapPath("link.mdb")
set rst=server.createobject("adodb.Recordset")
rst.open "select * from selflink order by 加入时间desc",con,3,1,1

'显示最新加入的3个连接
rst.movefirst
for i=1 to 3
response.write "<a href="&rst("地址")&">"&rst("网站名称")&"</a><br>"
rst.movenext
next

'从第4个到第20个记录中随机抽取7个
randomize
for i=1 to 7
rndtemp=rst.recordcount-1
curorrnd=Int((rndtemp-3+1)*Rnd()+3))
rst.move curorrnd,1
response.write "<a href="&rst("地址")&">"&rst("网站名称")&"</a><br>"
next

'关闭数据库,清除内存
rst.close
con.close
set rst=nothing
set con=nothing

此例在WIN98+PWS上调试成功,但在NT+IIS时指令:rst.move curorrnd,1可能会遇到困难,可做如下改动:
rst.movefirst
rst.move curorrnd

怎么样不是很难吧,试试看吧!:)加上这段程序后,每次刷新首页都能看到不同的连接。因为随机函数的几率是一样
的,这样才使那些加入“自助连接”的朋友有了相同的对待。
数据库开发 | .Net技术 | ASP技术 | PHP技术 | JSP技术 | 应用技术类 | 升蓝开发小组
Copyright ? 2001-2004 Shenzhen Hi-blue Software Team 升蓝开发小组 All rights reserved