PHP-yii框架 保存数据时,如果有同样的数据就覆盖,没有就插入新的一行

发布于 2017-05-23 00:06:14 字数 250 浏览 1509 评论 1

在使用yii框架处理表单提交的数据时,有这样的一个需求。
某个数据表有
id,code以及creatTime三个字段
其中id为主键,自增
code为一系列不重复的编码
在保存提交上来的数据时,要求,如果数据库里有与提交上来相同的code值那么就覆盖更新这条记录,否则就新增一行记录。
我在看YII的手册时,发现使用save()方法可以做到这一点。但是具体的不知道如何实现。
有朋友可以帮忙写个实例吗?非常感谢。。。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

瑾兮 2017-07-13 12:45:20

自己找到答案了。
来源自:http://www.yunxiu.org/blog/article/5445.htm
根据定义,只要isNewRecord属性为true,则进行插入。为false,就更新。

$model = new YourModel; //使用new关键字进行实例化, $model->isNewRecord 的值默认为true.
var_dump($model->isNewRecord); // true, 这种情况下使用 $model->save()为插入。

当你使用find查找到一条记录时,isNewRecord就会为false。

$model = YourModel::model()->findByPk(1);
var_dump($model->isNewRecord); //false
$model -> save() //此时为update操作

所以只需要先使用findByAttributes()找到code相同的一行数据进行save()操作就能进行更新。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文