博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
检验SQL语法
阅读量:5035 次
发布时间:2019-06-12

本文共 1723 字,大约阅读时间需要 5 分钟。

SET PARSEONLY

检查每个 Transact-SQL 语句的语法并返回任何错误信息,但不编译和执行语句。
语法
SET PARSEONLY { ON | OFF }
注释
当 SET PARSEONLY 为 ON 时,Microsoft® SQL Server? 仅分析语句。当 SET PARSEONLY 为 OFF 时,SQL Server 编译并执行语句。
SET PARSEONLY 的设置是在分析时设置,而不是在执行或运行时设置。
在存储过程或触发器中不要使用 PARSEONLY。如果 OFFSETS 选项为 ON 而且没有出现错误,则 SET PARSEONLY 返回偏移量。
权限
SET PARSEONLY 权限默认授予所有用户

===================

procedure   TForm1.Button1Click(Sender:   TObject);

var
  i:   Integer;
  strErrorList:   TStrings;
  begin
  try
      with   adoquery1   do
          begin
              sql.Clear;
              sql.Add( 'insert   into   yt   (ytname)   values( ');
              sql.Add( ' ' 'yt ' ' '+ ') ');
              adoquery1.ExecSQL;
          end;
      except
        begin
          listbox1.Items.Add(adoconnection1.Errors.Item[0].Description);
          listbox1.Items.Add(adoconnection1.Errors.Item[1].Source);
          listbox1.Items.Add(adoconnection1.Errors.Item[2].SQLState);
          listbox1.Items.Add(adoconnection1.Errors.Item[3].HelpFile);
        end;
  end;
end;

===========================================================

产生错误后从Errors中取得错误:如:

try
ADOQuery1.close;
ADOQuery1.open;
ADOQuery1.append;
ADOQuery1.FieldByName('ID').asinteger := 1;
ADOQuery1.post;
except
label1.caption := inttostr(ADOConnection1.Errors.Item[0].Get_Number);//取得错误号
label2.caption := ADOConnection1.Errors.Item[0].Get_Description;//取得描述信息
end;

===================================================================

try  

  ...  
  except  
  on   Er:exception   do  
  if   Er   is   EDBEngineError   then   //捕获EDB异常
    begin  
        ErCode:=EDBEngineError(Er).Errors[0].ErrorCode;  
        case   ErCode   of  
            ...  
          else  
            ...  
          end;  
        ...  
      end;  
  ...  
  //raise;   可重新引发异常,让全局异常处理子程序来进行处理。  
  ...  
  end;  

 
  try  
  ...  
  except  
  on   ex:exception   do  
  if   ex   is   EOleException   then  //捕获ADO异常
    msg:=EOleException(ex).Message  
  //iCode:=EOleException(ex).ErroCode;  
  ...  
    end;  
  ...  
  end;  

转载于:https://www.cnblogs.com/mingdep/archive/2012/02/03/2337388.html

你可能感兴趣的文章
系统管理玩玩Windows Azure
查看>>
c#匿名方法
查看>>
如何判断链表是否有环
查看>>
ssh无密码登陆屌丝指南
查看>>
MySQL锁之三:MySQL的共享锁与排它锁编码演示
查看>>
docker常用命令详解
查看>>
jQuery技巧大放送
查看>>
字符串转换成JSON的三种方式
查看>>
Hive时间函数笔记
查看>>
clojure-emacs-autocomplete
查看>>
一个自己写的判断2个相同对象的属性值差异的工具类
查看>>
10 华电内部文档搜索系统 search03
查看>>
[HDU1402]A * B Problem Plus(FFT)
查看>>
[CF803C] Maximal GCD(gcd,贪心,构造)
查看>>
逆时针旋转的矩阵变换
查看>>
第10周15/16/17
查看>>
四六级作文常见错误解析(转载)
查看>>
Tomcat
查看>>
./是当前目录 ../是当前的上一级目录。上上级就是../../一般绝对路径时候常用...
查看>>
树的递归与非递归遍历方法
查看>>