我正在使用 WebMatrix 2.0 RC 开发并喜欢它。我确定数据库设置正确,但我收到了这个错误:
Microsoft VBScript运行时
错误'800a01b6'
Object不支持此属性或方法:'id'
/myfile.asp,第24行
MYFILE.ASP
<%@ Language="VBScript" %>
<%
set db = Server.Createobject("ADODB.Connection")
db.open "Provider=Microsoft.SQLSERVER.CE.OLEDB.4.0;Data Source=" & server.mappath("/App_Data/databasefile.sdf")
%>
<%
set grs = Server.CreateObject("ADODB.recordset")
grs.Open "SELECT * FROM gells", db
do until grs.EOF
for each x in grs.Fields
response.write("<table style='margin-bottom:8px;'><tr><td style='vertical-align:top; padding-top:4px;'><img src='gells/uploads/gelthumbs/" & x.id & "_gelthumb.jpg' style='border:1px solid #FFFFFF;' /></td><td style='vertical-align:top; padding-left:4px; text-align:justify;'><strong>" & x.title & "</strong><br />" & x.info & "</td></tr><tr><td colspan='2' style='text-align:right; padding-top:4px;'><a href='gells.php?gelsid=" & x.id & "' ><img src='gells/viewgell.png' style='border:none;' /></a></td></tr></table>")
next
grs.MoveNext
loop
grs.close
%>
答案 0 :(得分:3)
代码中的x
变量将是Field对象。字段对象没有id
属性,因此出错。我怀疑id
,title
和info
实际上是您要使用的字段的名称。因此,您的代码应如下所示:
grs.Open "SELECT id, title, info FROM gells", db
do until grs.EOF
response.write "<table style='margin-bottom:8px;'><tr><td style='vertical-align:top; padding-top:4px;'><img src='gells/uploads/gelthumbs/" _
& Server.URLEncode(grs("id")) _
& "_gelthumb.jpg' style='border:1px solid #FFFFFF;' /></td><td style='vertical-align:top; padding-left:4px; text-align:justify;'><strong>" _
& Server.HTMLEncode(grs("title")) _
& "</strong><br />" & Server.HTMLEncode(grs("info")) _
& "</td></tr><tr><td colspan='2' style='text-align:right; padding-top:4px;'><a href='gells.php?gelsid=" _
& Server.URLEncode(grs("id")) _
& "' ><img src='gells/viewgell.png' style='border:none;' /></a></td></tr></table>"
grs.MoveNext
loop
grs.close
请注意,SQL仅包含您需要的字段,也不会直接从数据库发送未编码的数据。