FATAL ERROR未捕获错误:无法使用字符串键解压缩数组
我知道我可以简单地运行方法fetch()
两次并传递['q']
和['bind']
,但我正试图使用新的...
来解压缩值。我想传递这样的值:
(string) SQL, (Array) Bind Values
但我认为它试图从fetch()
方法解包绑定值数组以及响应数组。是否可以解压缩这个数组(看起来像这样:)
array(2) {
["q"]=> string(7) "example"
["bind"]=> array(1) {
["example"]=> string(3) "one"
}
}
这是整个代码,如果您需要了解它们如何组合在一起:
class ModelController {
public static function execute($sql, $vals) {
var_dump($vals);
}
}
class ModelContainer {
private $queries = [];
public function add_model(Model $model, $name) {
$this->queries[$name] = $model;
return $this;
}
public function exec_all() {
foreach($this->queries as $q) {
ModelController::execute(...$q->fetch());
}
}
public function exec($name) {
}
}
class Model {
private $sql;
private $vals = [];
public function set_q($statement) {
$this->sql = $statement;
return $this;
}
public function bind($vals = []) {
$this->vals = $vals;
return $this;
}
public function fetch() {
return ['q' => (string)$this->sql,
'bind' => $this->vals ];
}
}
$m = new ModelContainer();
$m->add_model((new Model)->set_q('example sql here')->bind(['example' => 'example value here']), 'one');
$m->exec_all();
答案 0 :(得分:20)
问题是“splat”运算符(数组解包运算符或...
)不适用于关联数组。例如:
$array = [1, 2, 3];
$assoc = ["one" => 1, "two" => 2, "three" => 3];
var_dump(...$array); //Works
var_dump(...$assoc); //Doesn't work
您需要强制对数组进行数字索引才能将其解压缩。您可以使用array_values执行此操作:
$values = array_values($q->fetch());
ModelController::execute(...$values);
数组值将确保所有值都具有顺序数字键。
答案 1 :(得分:1)
如果在尝试将关联数组拆包到另一个数组时遇到此错误,则可以改用Program Files (x86)
:
array_merge
会产生
<?php
$inner = ["b" => "i", "c" => "i"];
$outer = ["a" => "o", "c" => "o"];
var_dump(array_merge($outer, $inner));
var_dump(array_merge($inner, $outer));
答案 2 :(得分:1)
由于 PHP 8.1 解包数组也适用于字符串键数组,因此错误 FATAL ERROR Uncaught Error: Cannot unpack array with string keys
将不再适用。
示例:
$array1 = ["a" => 1];
$array2 = ["a" => 2];
$array = ["a" => 0, ...$array1, ...$array2];
var_dump($array); // ["a" => 2]
答案 3 :(得分:-1)
我在尝试为$ user提供Mailer方法时遇到了同样的问题。
$userMailer = new UserMailer();
$userMailer->send('welcome', [$user]);
将$ user粘贴到新阵列中应解决此问题。