特色栏目

ASP源码

PHP源码

.NET源码

JSP源码

游戏频道
专题合集
关闭菜单
首页> ASP教程> 关于recordcount等-1的问题

关于recordcount等-1的问题

时间:2009-06-25 17:46:20 作者:互联网

1
mssql--asp的rs***cordcount值为负1

只有以ADO方式调用数据库才有recordcount这一说,用存储过程需要用select count(*) from table_name自行统计
? 这个说的不对, 存储过程也可以用 ado 来打开,比如:rs.open "exec SomeProc", conn, 1, 3我处理解决的方法是rs.open sql,conn,1,1解决此问题
 
2
通常人们使用以下两种方法来执行SQL语句:
Set Rs***nn.Execute(SqlStr)

Set Rs***rver.CreateObject(“AD***.RecordSet“)
Rs.Open SqlStr,Conn,CursorType,LockType

(RecordSet对象方法请看这里)

由于默认的记录集游标是服务器游标,
Rs***rsorLocation = adUseServer
所以返回Rs***cordCount=-1,
应该把服务器游标改为客户端游标,
Rs***rsorLocation = adUseClient
Rs.Open SqlStr,Conn,CursorType,LockType

rs***rsortype

光标类型 recordcount 属性
---------------------------------------------
ForwardOnly 0(默认) 返回-1
Keyset 1 正确的记录数
Dynamic 2 -1或不正确的记录数,依数据源而定
Static 3 正确的记录数

所以Rs***rsorLocation = 3
可用re***dset.support("属性名")进行测试是否支持该属性。
http://www.dwww.cn/new/20051128112149636.html


3
Set oRs = Se***r.CreateObject("AD***.RecordSet")
oRs.Open sSql, oConn, 1, 1
来读数据,

要不就用Select Count(*) As RecordCount From [table]
oRs("RecordCount")来获取

要不就用Do While Not oRs.Eof
RecordCount = RecordCount + 1
Loop


4我的数据库是这么连接的:
strconn = "DRIVER=Microsoft Access Driver (*.mdb);DBQ=" & Se***r.MapPath("bbs.mdb")
set conn = se***r.createobject("ad***.connection")
co***open strconn
sql="SELECT * FROM space "
set rs=createobject("ad***.recordset")
rs.open sql,conn,1,1

可是的确有记录集返回
还可以显示

相关文章 最新文章

相关应用

热门文章

猜你喜欢

返回顶部