本文中所提到的asp页面,除特别声明外,均指<@PAGE LANGUEGE=”VBSCRIPT”>
写asp与数据库的结合的程序时,经常会遇到同一数据表中不允许存在重复值的问题,比如用户注册程序中不允许出现相同的用户ID。这样的情况下,我以前采取的办法是读取数据库中的已存在值,然后与用户输入的值比较,如果有相同,则提示已被注册,须重新填写。这样做可以达到预期的目的,但是因为有一次额外的数据库存取操作,比较浪费资源。
我们都知道,数据表中的列可以设置唯一性约束,就是从数据库限制该字段不允许出现重复值,违反唯一性约束后,数据库将返回2627错误,提示“违反了 %1! 约束 ''%2!''。不能在对象 ''%4!'' 中插入重复键”,这是数据库的输出,SQL Server 的所有错误都存储在系统表 master.dbo.sysmessages 中。用户定义的消息也可以存储在 sysmessages 中。在asp中调用存储过程的时候,由于存储过程没有容错处理,会返回该提示到页面,并终止语句的执行,@@Error返回值为0。如果页面设置了容错,则不会出现错误提示,但因为错误是数据库中出现的,所以Err.Number不能得到其错误号。(也可能是我的数据库不熟的原因:-),还请大虾指点)。近日研究ADO,找到了一种更加简便的方式实现该控制。
ADO(ActiveX Data Objects)被广泛的用于应用程序与数据库的连接,asp也可以通过他来实现对数据库的操作的。ADO 2.1的Connection对象中有一个Error对象,通过它可以捕捉到来自数据库的错误,以在asp页面中控制。该对象常用的Property有如下几个,均为只读:
Description:字符型,返回来自数据库的错误描述
Source:字符型,错误来源
SQLState:字符型,ODBC API(驱动程序管理器)错误,SQL Server 2000中对其有如下描述:
SQLSTATE 返回的字符串值由两个字符的类值后接三个字符的子类值组成。类值 01 表明是一种警告,后跟随 SQL_SUCCESS_WITH_INFO 的返回代码。只要类值不是 01(IM 除外),则表明是一种错误,后跟随 SQL_ERROR 的返回代码。类 IM 专门用于表明从 ODBC 实现产生的警告和错误。任何类中子类值 000 均用于实现给定类中所定义条件。这种类值和子类值的分配方法由 SQL-92 定义。
跑题了跑题了,回到刚才的话题~~~