`
clark1231
  • 浏览: 255501 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

ActiveRecord中处理find异常

阅读更多

当我们ActiveRecord中使用find的时候,如果表不存在或者字段错误了就会出现异常
那么怎么捕获异常呢?用begin当然可以,比如下面这个helper中写的


  def authenticate(userid, passwd)
    begin
      u = User.find(:first, :conditions=>["name = ? and passwd = ?", userid, passwd])
      raise "is_admin miss" if !u.is_admin
      #@userid, @is_valid_users, @is_admin_users = (u and u.id ? [u.name,u.is_valid,u.is_admin] : [nil,false,false])
    rescue
      @err = $!
    else
      @err = nil
    end
  end
那现在就有个问题了,要find的地方很多的话那不是每个find都要写begin ?
当然不是了,有解决方法,具体的原理就是扩展 find 方法,下面就开始一步一步做

#先建个抽象model类,因为要所有find生效,所以建个抽象类,相当于中间类
>ruby script\generate model abstract_model

#编辑 app\models\abstract_model.rb 内容如下
class AbstractModel < ActiveRecord::Base
  self.abstract_class = true  #这个很重要,详见 http://blog.vkill.net/read.php/161.htm
  #这个方法是扩展find,加上异常处理
  def self.find(*args)
    begin
      super
    rescue => err
      @errors = err.message
    end
  end
  #这个方法是查询错误
  def self.errors_full_message()
    @errors || nil
  end
end

#修改User类为抽象类的子类,编辑 app\models\user.rb 内容如下
class User < AbstractModel
end

#如何使用呢?还是最开始的那个helper例子,现在变的很简单了吧,呵呵
  def authenticate(userid, passwd)
    u = User.find(:first, :conditions=>["name = ? and passwd = ?", userid, passwd])
    if err = User.errors_full_message
      @err_auth = err
    else
      if u
        begin
          @userid, @is_valid_users, @is_admin_users = (u and u.id ? [u.name,u.is_valid,u.is_admin] : [nil,false,false])
        rescue =>err
          @err_auth = err.message
        else
          @err_auth = nil
        end
      else
        @err_auth = 'auth error, userid or passwd error'
      end
    end
  end

这个的重点就是扩展原有的类方法
分享到:
评论

相关推荐

    ASP实现ActiveRecord数据查询更新 v1.0-ASP源码.zip

    7. **错误处理**:在实现中,还需要考虑错误处理,确保在出现异常时能够适当地关闭连接并抛出错误信息。 这个压缩包中的源码可能包含了上述步骤的示例实现,你可以通过解压并查看代码来学习如何在ASP中应用...

    Ruby-Spyke与REST服务交互用一种类似于ActiveRecord的管理器

    ActiveRecord使得数据库操作变得极其简单,它允许开发者以面向对象的方式处理数据。然而,当我们需要与RESTful API进行交互时,虽然可以直接使用HTTP库如Net::HTTP或HTTParty,但这些库往往缺乏ActiveRecord那样的...

    W5D5:W5D5 Classwork-Rails ActiveRecord查询

    `同样表示异常处理。 - `destroy`, `destroy_all`: 删除单个或所有匹配的记录。 总结来说,“W5D5: W5D5 Classwork - Rails ActiveRecord查询”涵盖了如何在Ruby on Rails中使用ActiveRecord高效地操作数据库,包括...

    pdo_model:PDOModel - 使用 PDO(PHP 数据对象)的类似 DataModel 类的 ActiveRecord

    6. **错误处理和异常处理**:当发生数据库操作错误时,PDOModel 会抛出异常,便于进行错误处理和调试。 7. **查询构建器**:虽然 PDOModel 通常隐式处理 SQL,但它也可能提供一个查询构建器,允许开发者更灵活地...

    Ruby的25个编程细节(技巧、实用代码段)

    使用 `try` 方法处理潜在的异常 在Ruby中,`try` 方法是一个非常有用的功能,它允许我们安全地访问对象的方法或属性,即使该对象为 `nil` 也不会抛出异常。相反,如果没有找到对象或者对象为 `nil`,`try` 会返回 ...

    CakePHP 1.2 API 中文文档

    在 CakePHP 1.2 中,ORM(对象关系映射)称为ActiveRecord,使得数据库操作更加直观。例如,通过 `$this-&gt;Article-&gt;find()` 方法可以轻松获取文章数据。此外,它支持CRUD(创建、读取、更新、删除)操作,简化了...

    Laravel开发-table-helper

    5. **错误处理**:统一处理数据库操作中可能出现的异常,提供友好的错误信息。 6. **性能优化**:可能包含缓存策略,避免频繁的数据库查询,提高系统性能。 7. **日志记录**:记录重要的数据库操作,便于追踪和...

    Ruby on Rails 指南 v5.0.1 中文版

    - **ActiveRecord和引用完整性**:讨论如何在Rails中处理外键约束和其他引用完整性的问题。 - **迁移和种子数据**:说明如何在迁移过程中插入初始数据。 #### ActiveRecord数据验证 - **数据验证概览**:提供数据...

    thinkphp3.2.3-demo

    ThinkPHP的ActiveRecord模式使得数据库操作变得直观,比如`$this-&gt;where(array('username'=&gt;$username))-&gt;find()`。 4. **密码验证**:在数据库中,用户密码通常经过加密存储,因此在验证时也需要进行解密。...

    thinkphp_thinkphp_thinkphp5_

    通过设置全局异常处理器和错误处理器,可以统一处理运行时的异常和错误。同时,日志系统支持多种驱动,方便开发者记录和分析程序运行状态。 总的来说,这个压缩包提供的模板实例是学习和实践ThinkPHP5的好素材。...

    Laravel开发-laravel-crud

    9. **错误处理和日志**:Laravel的异常处理和日志系统可以帮助开发者调试和优化代码。错误信息会被自动捕获并记录在`storage/logs/laravel.log`文件中。 10. **Middleware**:中间件在请求生命周期中起到拦截和处理...

    记录存储-带成本-SQL-Ruby-Week-3

    例如,我们可以使用ActiveRecord的`find_by_sql`方法直接执行自定义的SQL语句,或者利用其内置的查询接口,如`where`、`sum`、`average`等,来实现更安全、更易于维护的查询。 此外,我们还需要关注性能优化。当...

    thinkphp6.1的框架源文件,不用安装composer麻烦下载了,直接原版框架

    8. **错误处理和日志**:ThinkPHP6.1提供了统一的错误处理机制,包括异常处理和错误日志记录。开发者可以根据需求自定义错误处理和日志级别。 9. **命令行工具**:框架内建了一个命令行工具`think`, 可以用于执行...

    thinkphp5.0

    其异常处理机制使得错误报告更加规范,便于定位问题。 六、命令行工具 TP5的命令行工具提供了一系列命令,如创建控制器、模型、迁移等,极大地提高了开发效率。 七、性能优化 TP5在性能方面做了诸多优化,如路由...

    11种连接数据库的方法

    数据库是存储和管理数据的核心工具,...在实际应用中,确保正确处理异常、关闭连接以及优化SQL查询是提高性能的关键。同时,随着技术的发展,如ORM的普及,数据库连接的方式也在不断进化,为开发者带来了更多的便利。

    使用rails6开发纯后端API项目.zip

    可以自定义错误类,使用`rescue_from`处理异常,并返回适当的HTTP状态码和错误消息。 10. **Authentication与Authorization** JSON Web Tokens (JWT) 或 Devise 是常见的认证解决方案。JWT允许无状态认证,而...

    ThinkPHP2.0完全开发手册及API手册

    9. **错误处理与日志记录**:阐述了ThinkPHP2.0的错误处理机制,包括异常处理、错误级别设定,以及日志记录功能。 10. **安全与优化**:讨论了防止SQL注入、XSS攻击的安全措施,以及性能优化技巧,如缓存机制、数据...

    Ruby-MongoidMongoDB的RubyODMObjectDocumentMapper框架

    Mongoid对数据库操作的错误进行了封装,当发生错误时,会抛出相应的Mongoid异常,如`Mongoid::Errors::DocumentNotFound`等,便于开发者捕获和处理。 总结来说,Ruby-Mongoid是Ruby开发者在MongoDB上的强大工具,...

    ruby on rails 3.1.0数据库查询方法汇总

    - `find_each` 方法适用于大量数据的处理,每次只处理少量记录,避免内存占用过高。 12. **数据更新和删除**: - `c = Category.first` - `c.destroy` - 删除当前实例对应的数据库记录。 - `Category.delete(2...

    Yii2框架中一些折磨人的坑

    解决这个问题的方法是确保输入的日期字符串与指定的`format`匹配,或者在验证规则中使用更宽松的格式,或者添加适当的异常处理。 总之,Yii2框架虽然强大,但也有一些需要注意的地方。通过理解ActiveRecord的工作...

Global site tag (gtag.js) - Google Analytics