日期:2012-09-24  浏览次数:20754 次

 

我原先用MDB的数据库,用ASP写的一个系统。

由于没有经验,使用了where字段。

最近由于需要把数据库导成SQL的,导成功之后。我在调试时发现很多的使用了"rs.update"的代码会提示在where附近有语法错误。郁闷的我查了很多资料,同时也自己试了大半天。直到下午我才最终肯定,是where字段出了问题。

调试的结论是用update语句可以,但就是不能用rs.update来实现更新;更名正常,但工作量太大;删去正常,但不能删。在7917375群内和气气等人讨论好长时间也拿不出什么好的其它的方法来。所以发到这里,希望有人能够帮忙解决。

这一次是用不了,我只好麻烦地替换可以替换的,一次次地调试了。。

在此向各位同仁提醒,在表单设计时最好不要用数据库保留字段。
在SQL中表现为自动更改为[段名],在MDB请恕我愚钝看不出来。。

==================附调试信息

sql:
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[test]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table [dbo].[test]
GO

CREATE TABLE [dbo].[test] (
 [id] [bigint] IDENTITY (1, 1) NOT NULL ,
 [where] [char] (10) COLLATE Chinese_PRC_CI_AS NULL ,
 [names] [char] (10) COLLATE Chinese_PRC_CI_AS NULL
) ON [PRIMARY]
GO
第一次导这样的脚本,希望能用。

ASP:

<%@LANGUAGE="VBSCRIPT" CODEPAGE="936"%>
<%
 connstr="driver={SQL Server};server=localhost;uid=sa;pwd=;database=test"
 set conn=Server.CreateObject("ADODB.Connection")
  conn.Open connstr

 sql="select * from test where id=1"
 set rs=server.createobject("adodb.recordset")
 rs.open sql,conn,1,3
 rs("names")="test"
  rs.update
 rs.close
 set rs=nothing

set conn=nothing
%>