当我们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
这个的重点就是扩展原有的类方法
分享到:
相关推荐
7. **错误处理**:在实现中,还需要考虑错误处理,确保在出现异常时能够适当地关闭连接并抛出错误信息。 这个压缩包中的源码可能包含了上述步骤的示例实现,你可以通过解压并查看代码来学习如何在ASP中应用...
ActiveRecord使得数据库操作变得极其简单,它允许开发者以面向对象的方式处理数据。然而,当我们需要与RESTful API进行交互时,虽然可以直接使用HTTP库如Net::HTTP或HTTParty,但这些库往往缺乏ActiveRecord那样的...
`同样表示异常处理。 - `destroy`, `destroy_all`: 删除单个或所有匹配的记录。 总结来说,“W5D5: W5D5 Classwork - Rails ActiveRecord查询”涵盖了如何在Ruby on Rails中使用ActiveRecord高效地操作数据库,包括...
6. **错误处理和异常处理**:当发生数据库操作错误时,PDOModel 会抛出异常,便于进行错误处理和调试。 7. **查询构建器**:虽然 PDOModel 通常隐式处理 SQL,但它也可能提供一个查询构建器,允许开发者更灵活地...
使用 `try` 方法处理潜在的异常 在Ruby中,`try` 方法是一个非常有用的功能,它允许我们安全地访问对象的方法或属性,即使该对象为 `nil` 也不会抛出异常。相反,如果没有找到对象或者对象为 `nil`,`try` 会返回 ...
在 CakePHP 1.2 中,ORM(对象关系映射)称为ActiveRecord,使得数据库操作更加直观。例如,通过 `$this->Article->find()` 方法可以轻松获取文章数据。此外,它支持CRUD(创建、读取、更新、删除)操作,简化了...
5. **错误处理**:统一处理数据库操作中可能出现的异常,提供友好的错误信息。 6. **性能优化**:可能包含缓存策略,避免频繁的数据库查询,提高系统性能。 7. **日志记录**:记录重要的数据库操作,便于追踪和...
- **ActiveRecord和引用完整性**:讨论如何在Rails中处理外键约束和其他引用完整性的问题。 - **迁移和种子数据**:说明如何在迁移过程中插入初始数据。 #### ActiveRecord数据验证 - **数据验证概览**:提供数据...
ThinkPHP的ActiveRecord模式使得数据库操作变得直观,比如`$this->where(array('username'=>$username))->find()`。 4. **密码验证**:在数据库中,用户密码通常经过加密存储,因此在验证时也需要进行解密。...
通过设置全局异常处理器和错误处理器,可以统一处理运行时的异常和错误。同时,日志系统支持多种驱动,方便开发者记录和分析程序运行状态。 总的来说,这个压缩包提供的模板实例是学习和实践ThinkPHP5的好素材。...
9. **错误处理和日志**:Laravel的异常处理和日志系统可以帮助开发者调试和优化代码。错误信息会被自动捕获并记录在`storage/logs/laravel.log`文件中。 10. **Middleware**:中间件在请求生命周期中起到拦截和处理...
例如,我们可以使用ActiveRecord的`find_by_sql`方法直接执行自定义的SQL语句,或者利用其内置的查询接口,如`where`、`sum`、`average`等,来实现更安全、更易于维护的查询。 此外,我们还需要关注性能优化。当...
8. **错误处理和日志**:ThinkPHP6.1提供了统一的错误处理机制,包括异常处理和错误日志记录。开发者可以根据需求自定义错误处理和日志级别。 9. **命令行工具**:框架内建了一个命令行工具`think`, 可以用于执行...
其异常处理机制使得错误报告更加规范,便于定位问题。 六、命令行工具 TP5的命令行工具提供了一系列命令,如创建控制器、模型、迁移等,极大地提高了开发效率。 七、性能优化 TP5在性能方面做了诸多优化,如路由...
数据库是存储和管理数据的核心工具,...在实际应用中,确保正确处理异常、关闭连接以及优化SQL查询是提高性能的关键。同时,随着技术的发展,如ORM的普及,数据库连接的方式也在不断进化,为开发者带来了更多的便利。
可以自定义错误类,使用`rescue_from`处理异常,并返回适当的HTTP状态码和错误消息。 10. **Authentication与Authorization** JSON Web Tokens (JWT) 或 Devise 是常见的认证解决方案。JWT允许无状态认证,而...
9. **错误处理与日志记录**:阐述了ThinkPHP2.0的错误处理机制,包括异常处理、错误级别设定,以及日志记录功能。 10. **安全与优化**:讨论了防止SQL注入、XSS攻击的安全措施,以及性能优化技巧,如缓存机制、数据...
Mongoid对数据库操作的错误进行了封装,当发生错误时,会抛出相应的Mongoid异常,如`Mongoid::Errors::DocumentNotFound`等,便于开发者捕获和处理。 总结来说,Ruby-Mongoid是Ruby开发者在MongoDB上的强大工具,...
- `find_each` 方法适用于大量数据的处理,每次只处理少量记录,避免内存占用过高。 12. **数据更新和删除**: - `c = Category.first` - `c.destroy` - 删除当前实例对应的数据库记录。 - `Category.delete(2...
解决这个问题的方法是确保输入的日期字符串与指定的`format`匹配,或者在验证规则中使用更宽松的格式,或者添加适当的异常处理。 总之,Yii2框架虽然强大,但也有一些需要注意的地方。通过理解ActiveRecord的工作...