我的应用场景是这样:Order主表,OrderProduct放Order里面有一个hasMany的关联,当保存订单表时先get并with了order_product。没有获取到数据我会将新的数据插入数据库,那第一条的order_product(也就是子表)插入的sql会返回0;导致主表order被插入两次。分析代码发现hasMany里面会把OrderProduct的field属性改为['order_product.*'];ThinkPHP原来的代码这里无法将本来的字段分析出来。我临时改为以下方案,请管理员提出更好的方案。
// 这里由fely修改了BUG,当调用HasOne, HasMany这些聚合函数后,这里的field出现问题,导致插入失败
if ('*' == $options['field']) {
$fields = array_keys($bind);
}
else if (is_array($options['field']) && count($options['field']) === 1 && strrpos($options['field'][0], '.*') >= 0) {
$fields = array_keys($bind);
}else {
$fields = $options['field'];
}
/*if ('*' == $options['field']) {
$fields = array_keys($bind);
} else {
$fields = $options['field'];
}*/ 最佳答案