zoukankan      html  css  js  c++  java
  • 几种捕获ClientDataSet.ApplyUpdates和SocketConnection异常的方法比较

     问题:如何捕获ClientDataSet.ApplyUpdates的错误,不用ReconcileError呢?

    //如果用这个错误处理,我的事务回滚却不知放在何处才妙,并且我不是想用这个错误处理
    解答一:
    //---------------------------------------------------------------
    //据我所知,只能用ReconcileError 可以用下面的方法判断是否错误
    //---------------------------------------------------------------
    解答二:
    //---------------------------------------------------------------
    在DataSetProvider的onUpdateError


    然后就可以在客户端做如下处理:


    //----------------------------------------------------------------
    解答三:
       其实真正的捕获ClientDataSet.ApplyUpdate异常的方法应该是在Apllication的异常中捕获并处理它。因为 ClientDataSet抛出的异常为线程(进程?)异常,在ClientDataSet的ApplyUpdate中用 try...except...end;是无法捕获的。

       具体方法为:在公共单元如DataModule中放置一个ApplicationEvent件,在该控件的OnException事件中捕获异常,该窗体应在所有有可能产生ApplyUpdate或Connection异常的窗体之前创建。


    更深入更详细的分析可参考: http://blog.csdn.net/xieyunc/archive/2009/04/28/4131958.aspx
  • 相关阅读:
    php RabbitMQ使用
    phalcon: 开启模板缓存和缓存路径
    phalcon:整合官方多模块功能,方便多表查询
    mysql: 模糊查询 feild like keyword or feild like keyword , concat(feild1,feild2,feild3) like keyword
    php的http数据传输get/post...
    java大数字操作:BigInteger,BigDecimal(浮点型)
    DecimalFormat数据格式函数
    MySQL比like语句更高效的写法locate position instr find_in_set
    mysql中使用instr替换like
    mysql中的多行查询结果合并成一个
  • 原文地址:https://www.cnblogs.com/xieyunc/p/2793765.html
Copyright © 2011-2022 走看看