SQL SERVER2000数据库深入学习之常见错误
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
SQL server2000数据库深入学习之常见错误SQL SERVER2000深入学习之常见错误
/*数据库编程中常见的错误*/
--(1)处理空值
--(2)从结果集中对变量进行赋值
--(3)没有受影响的记录
--(4)错误大小或数据类型
--(5)默认长度所引发错误
--(6)触发器回滚
--(7)警告和优先级错误
--(8)嵌套注释
--(9)延迟名称解析
--(10)游标
--(11)过分自信
/* for example*/
--(1) 处理空值
--wrong->follow
--if @score=null (except set Ansi_Nulls off)
--if @score<>null
--Right
--if @score is null
--if @score is not null
--(2) 从结果集中对变量进行赋值
--未考虑返回记录集为空时并未对变量进行初始化所引起的问题
--当想返回给变量记录集最后一条记录可能出错,因为有时很难预测最后一条记录时哪一条
--这取决于所用的索引和查询
--(3) 没有受影响的记录
--有时或许我们需要假设当T-SQL语句没有影响任何记录时,SQL-server 将返回错误
--因为其是逻辑错误所以不可用@@Error来检测,应用@@rowCount
--(5)默认长度
/*
declare @vchardef varchar
set @vchardef='123456789012345678901234567890'
select datalength(@vchardef),@vchardef
--将返回1 1
*/
/* the follow is right
declare @vchardef varchar(30)
set @vchardef='123456789012345678901234567890'
select datalength(@vchardef),@vchardef
*/
(6) )延迟名称解析
--Set Xact_Abort On
--语句强制SQL_SERVER在出现错误时回滚整个事务,并停止进一步执行,停止当前批处理的执行,错误均被当成致命错误
--但是其不会检测到“编译错误中应延迟名称解析的原因而未在编译阶段发现的错误”如更新不存在的表
--因而并不在错误发生时回滚,而是继续提交和执行
此文章出自达思SQL数据库修复软件/soft/110811.htm
/download/64222.html。