最近发现,论坛好多朋友都提到这个问题,就是自动完成、自动验证无效。
很不幸昨天我也遇到了相同的问题,死活不生效,测试了半小时无果,因为这个过程发生在create()方法中,所以跟踪了create(),
发现了一个很大的秘密,原来create()方法原来有两个参数,
第一个参数是大家都知道了数据参数,第二个是隐藏的$type参数,这个参数用来控制什么的呢??
- // 状态$type =
$type?$type!empty($data[$this->getPk()])?self::MODEL_UPDATE:self::MODEL_INSERT);
discount nike air shoes
仔细琢磨了这句话才发现,这个隐藏参数是用来指明本次数据库具体是什么操作的,1即为插入操作,0即为更新操作,
默认的情况下是不用给这个参数赋值的,原因是,系统能自动识别
它是这么识别的:
如果您传入的数据中有与主键相同字段的,则本次数据库操作则默认为更新操作,这么判断主要是因为大部分情况主键都是默认自增的,插入操作一般不会给主键赋值,但问题就出在这里
我最近做的项目直接把学号作为主键,而学号不能使用自增而是有固定格式的,得录入,
但是系统就自动把我的录入操作当成了更新操作,而我的自动完成代码都是这么写的:
- protected
$_auto = array(
-
array('majorid','maxmajoridadd1',1,'callback'),
-
);
第三个参数1查看手册就知道是指这个自动完成操作是在插入时候执行的。
而系统把我的插入操作当成了更新操作,我设置的自动完成代码自然就失效而不被执行了
front
lace wig
这是非常难以发现的问题,最近发现论坛里好多人遇到此问题,特此撰文说明。
此外自动验证/自动完成功能失效还有可能是你的Model类名称写错了之类的,我就犯过这种错误,多个字母少个字母经常的事情
基本上自动验证/自动完成失效就这两种情况
对了,忘了说明如何解决这个问题了
当出现了你也要录入主键字段值的情况的时候您可以这么写
create($_POST,1)
直接告诉create方法此次操作是插入操作
|