PHP-yii框架 保存数据时,如果有同样的数据就覆盖,没有就插入新的一行
在使用yii框架处理表单提交的数据时,有这样的一个需求。
某个数据表有
id,code以及creatTime三个字段
其中id为主键,自增
code为一系列不重复的编码
在保存提交上来的数据时,要求,如果数据库里有与提交上来相同的code值那么就覆盖更新这条记录,否则就新增一行记录。
我在看YII的手册时,发现使用save()方法可以做到这一点。但是具体的不知道如何实现。
有朋友可以帮忙写个实例吗?非常感谢。。。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
自己找到答案了。
来源自: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()操作就能进行更新。