这一段时间,敲了两个系统,遇到了很多“小问题”,总结一下。
1.对象变量或With块变量未设置
这是我们经常遇到的问题,产生此类问题的原因很多,我们这段时间是用VB和数据库交互的,所以现阶段引起此类问题的主要原因是:数据库未连接!解决此问题的方法是查看数据库连接字符串是否正确,进行测试。
2.BOF或EOF中有一个是真,或者当前记录已被删除,要求一个当前记录
用到数据库时经常出现这个问题,可能原因是查询的数据表里无记录,当用到MoveFirst或MoveLast等时就会产生此类错误,因为数据表为空时EOF和BOF同时为True。解决方法有很多种,比如加上判断:
If mrc.RecordCount = 0 Then '判断记录集是否存在记录 MsgBox "没有记录!" Exit Sub End If或者使用错误处理:
On ErrorResumeNext RSS.MoveFirst if Err=3021 then Response.write "无数据!" End If3.多步OLE DB操作产生错误
产生此错误的原因可能是:数据类型或长度的输入与数据库设定的不符,导致输入的数据无法存入数据库中!解决方法是根据报错的代码所显示的数据库表,查看数据库表中的类型和长度,并在输入时设定上限制。为了防止这类问题的发生,在设计时,应该先设计好数据库中各字段存储的数据类型,根据类型和长度,在VB中限定相对应的类型和长度,防止此类错误的发生。
4.对象关闭时不允许操作
这个问题很简单,但是很容易犯这样的错误,产生原因:如果需要某些表中的记录,则需要对表进行操作,表示打开表失败。解决方法是测试所需要的表是否进行了打开的操作,进行测试!
这个问题报错时会报 “对象变量或With块变量未设置” 需要调试查出真正出问题的地方,产生此问题的一般原因是数据库表的名称和数据库的关键字相同,解决方法很简单,将数据库表名用[ ]括起来就行了!
下面这些词都是T-sql语句中的关键字,在你写sql语句,存储过程,触发器或字段命名等时要避免使用这些词!
ADD |
EXIT |
PRIMARY |
@H_403_140@
ALL |
FETCH |
|
@H_403_140@
ALTER |
FILE |
PRIVILEGES |
@H_403_140@
AND |
FILLFACTOR |
PROC |
@H_403_140@
ANY |
FLOPPY |
PROCEDURE |
@H_403_140@
AS |
FOR |
PROCESSEXIT |
@H_403_140@
ASC |
FOREIGN |
PUBLIC |
@H_403_140@
AUTHORIZATION |
FREETEXT |
RAISERROR |
@H_403_140@
AVG |
FREETEXTTABLE |
READ |
@H_403_140@
BACKUP |
FROM |
READTEXT |
@H_403_140@
BEGIN |
FULL |
RECONFIGURE |
@H_403_140@
BETWEEN |
GOTO |
REFERENCES |
@H_403_140@
BREAK |
GRANT |
REPEATABLE |
@H_403_140@
BROWSE |
GROUP |
REPLICATION |
@H_403_140@
BULK |
HAVING |
RESTORE |
@H_403_140@
BY |
HOLDLOCK |
RESTRICT |
@H_403_140@
CASCADE |
IDENTITY |
RETURN |
@H_403_140@
CASE |
IDENTITY_INSERT |
REVOKE |
@H_403_140@
CHECK |
IDENTITYCOL |
RIGHT |
@H_403_140@
CHECKPOINT |
IF |
ROLLBACK |
@H_403_140@
CLOSE |
IN |
ROWCOUNT |
@H_403_140@
CLUSTERED |
INDEX |
ROWGUIDCOL |
@H_403_140@
COALESCE |
INNER |
RULE |
@H_403_140@
COLUMN |
INSERT |
SAVE |
@H_403_140@
COMMIT |
INTERSECT |
SCHEMA |
@H_403_140@
COMMITTED |
INTO |
SELECT |
@H_403_140@
COMPUTE |
IS |
SERIALIZABLE |
@H_403_140@
CONFIRM |
ISOLATION |
SESSION_USER |
@H_403_140@
CONSTRAINT |
JOIN |
SET |
@H_403_140@
CONTAINS |
KEY |
SETUSER |
@H_403_140@
CONTAINSTABLE |
KILL |
SHUTDOWN |
@H_403_140@
CONTINUE |
LEFT |
SOME |
@H_403_140@
CONTROLROW |
LEVEL |
STATISTICS |
@H_403_140@
CONVERT |
LIKE |
SUM |
@H_403_140@
COUNT |
LINENO |
SYSTEM_USER |
@H_403_140@
CREATE |
LOAD |
TABLE |
@H_403_140@
CROSS |
MAX |
TAPE |
@H_403_140@
CURRENT |
MIN |
TEMP |
@H_403_140@
CURRENT_DATE |
MIRROREXIT |
TEMPORARY |
@H_403_140@
CURRENT_TIME |
NATIONAL |
TEXTSIZE |
@H_403_140@
CURRENT_TIMESTAMP |
NOCHECK |
THEN |
@H_403_140@
CURRENT_USER |
NONCLUSTERED |
TO |
@H_403_140@
CURSOR |
NOT |
TOP |
@H_403_140@
DATABASE |
NULL |
TRAN |
@H_403_140@
DBCC |
NULLIF |
TRANSACTION |
@H_403_140@
DEALLOCATE |
OF |
TRIGGER |
@H_403_140@
DECLARE |
OFF |
TRUNCATE |
@H_403_140@
DEFAULT |
OFFSETS |
TSEQUAL |
@H_403_140@
DELETE |
ON |
UNCOMMITTED |
@H_403_140@
DENY |
ONCE |
UNION |
@H_403_140@
DESC |
ONLY |
UNIQUE |
@H_403_140@
DISK |
OPEN |
UPDATE |
@H_403_140@
DISTINCT |
OPENDATASOURCE |
UPDATETEXT |
@H_403_140@
DISTRIBUTED |
OPENQUERY |
USE |
@H_403_140@
DOUBLE |
OPENROWSET |
USER |
@H_403_140@
DROP |
OPTION |
VALUES |
@H_403_140@
DUMMY |
OR |
VARYING |
@H_403_140@
DUMP |
ORDER |
VIEW |
@H_403_140@
ELSE |
OUTER |
WAITFOR |
@H_403_140@
END |
OVER |
WHEN |
@H_403_140@
ERRLVL |
PERCENT |
WHERE |
@H_403_140@
ERROREXIT |
PERM |
WHILE |
@H_403_140@
ESCAPE |
PERMANENT |
WITH |
@H_403_140@
EXCEPT |
PIPE |
WORK |
@H_403_140@
EXEC |
PLAN |
WRITETEXT |
@H_403_140@
EXECUTE |
PRECISION |
@H_403_140@ |
EXISTS |
PREPARE |
@H_403_140@ |