|
我原先用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 %>
|