开发者社区> 问答> 正文

问题出现:致命错误:[]运算符不支持字符串

我从数据库中获取信息,将其保存在数组中,并以具有循环结构的形式回显它,当我尝试将修改后的信息保存到数据库时遇到问题。

我收到此错误:

致命错误:字符串中不支持[]运算符。

码:

$namesql1 = "SELECT name,date,text,date2 FROM table WHERE something= '$something'";
$nameresult1 = mysql_query($namesql1);
$countrows = mysql_num_rows($nameresult1);
while ($row = mysql_fetch_array($nameresult1, MYSQL_ASSOC)) {
    $name[] = $row['name'];
    $date[] = $row['date'];
    $text[] = $row['text'];
    $date2[] = $row['date2 '];
}

/** SOME CODE HERE **/

$wrotesql = "UPDATE service_report SET  name ='$name' , $date = '$date',$text = '$text[$nro]', ser_date = '$date2[$nro]' WHERE something = '$something')";

$wroteresult = mysql_query($wrotesql);

有人可以给我一个提示我做错了什么吗?

谢谢。

展开
收起
保持可爱mmm 2020-05-13 11:42:22 374 0
1 条回答
写回答
取消 提交回答
  • 尝试在字符串上使用短数组推送语法时,会出现此错误。

    例如这个

    $foo = 'foo'; $foo[] = 'bar'; // ERROR! 我大胆猜测的一个或多个你的$name,$date,$text或$date2变量已经被初始化为一个字符串。

    编辑:再次查看您的问题,似乎您实际上并不想将它们用作数组,因为您将它们当作更进一步的字符串来对待。

    如果是这样,请将您的分配更改为

    $name = $row['name']; $date = $row['date']; $text = $row['text']; $date2 = $row['date2']; 似乎PHP 7和使用empty-index数组推语法的代码存在一些问题。

    明确地说,这些在PHP 7+中可以正常工作

    $previouslyUndeclaredVariableName[] = 'value'; // creates an array and adds one entry

    $emptyArray = []; // creates an array $emptyArray[] = 'value'; // pushes in an entry 什么是不工作正在尝试使用空指数上宣布为字符串,数字,对象等,即任何变量推

    $declaredAsString = ''; $declaredAsString[] = 'value';

    $declaredAsNumber = 1; $declaredAsNumber[] = 'value';

    $declaredAsObject = new stdclass(); $declaredAsObject[] = 'value'; 所有这些都会导致致命错误。来源:stack overflow

    2020-05-13 11:42:36
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载

相关实验场景

更多