微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Kohana ORM更新不起作用

如何解决Kohana ORM更新不起作用

| 我仅在两天前就发现了Kohana,在遇到一些问题并设法解决这些问题后,我遇到了一个非常奇怪的问题。 当我尝试更新数据库中的条目时,而不是更新条目,ORM只会插入新行。 一切都与该示例类似:http://kohanaframework.org/3.0/guide/orm/examples/simple 我的代码(控制器文件):
class Controller_Admin extends Controller {
   ...
   public function action_test($id)
   {
      $inquiry = ORM::factory(\'inquiry\')->where(\'Id\',\'=\',$id)->find(); // $inquiry  = Model_Inquiry($id) doesn\'t work,too
      $inquiry ->Name = \'Someone\';
      $inquiry ->save();
   }
   ...
}
模型文件
class Model_Inquiry extends ORM
{
    protected $_table_name = \'mytable\';
}   
您有什么主意为什么要插入一个新条目而不是更新旧条目?我读到这是因为ID设置不正确,但是我尝试使用固定值(-> where(\'Id \',\'= \',5)),但是它不起作用(它仍然插入了新行)。 提前致谢!     

解决方法

        您的记录未首先加载。要检查是否已加载,请执行以下操作:
if ($inquiry->loaded()){...
另外,您可以通过执行以下操作来检查已运行的查询:
echo $inquiry->last_query();
因此,您可以手动检查返回给ORM的确切信息。 这里的主要问题是您正在使用
save()
而不是更严格地使用and5ѭ/
update()
。如果您使用“ 6”,ORM将抛出异常,抱怨记录未加载。 Save基本上是这些方法的代理,具体取决于加载的状态。 (我假设您使用的是Kohana 3.1,因为3.0 ORM根本没有单独的更新/创建方法)     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。