49

我正在使用 000webhost.com 并且在那里使用 phpMyAdmin。如标题所示,当我运行 PHP 脚本时,我从 MySQL 收到此错误:

mysql.proc 的列数错误。预计 20 个,发现 16 个。

该表可能已损坏。

有什么解决办法吗?

<?php
$username="usrname";
$password="passwd";
$database="a1xxxxx_mydb";
$host="mysqlxx.000webhost.com";
mysql_connect($host,$username,$password);
@mysql_select_db($database) or die( "Unable to select database");
if (isset($_GET["userLatitude"]) && isset($_GET["userLongitude"])) {

 $userLatitude=$_GET['userLatitude']; 
 $userLongitude=$_GET['userLongitude']; 
 $result = mysql_query("SELECT locationName, ( 6371 * acos( cos( radians(floatval(     $userLatitude) )) * cos( radians( locationLatitude ) ) * cos( radians( locationLongitude ) - radians( floatval($userLatitude)) ) + sin( radians(floatval($userLongitude)) ) * sin( radians( locationLatitude) ) ) ) AS distance 
         FROM Location HAVING distance < 2 ORDER BY distance LIMIT 0 ,20") or die(mysql_error()); 
echo $result;

 // check for empty result
if (mysql_num_rows($result) > 0) {
   // looping through all results
   // products node
  $response["Location"] = array();

  while ($row = mysql_fetch_array($result)) {
    // temp user array
    $product = array();
    $product["locationName"] = $row["locationName"];
    $product["locationInfo"] = $row["locationInfo"];
    $product["locationLatitude"] = $row["locationLatitude"];
    $product["locationLongitude"] = $row["locationLongitude"];
    $product["locationPic"] = $row["locationPic"];
    $product["city"] = $row["city"];

    // push single product into final response array
    array_push($response["Location"], $product);
 }
 // success
 $response["success"] = 1;

   // echoing JSON response
   echo json_encode($response);
 } else {
// no products found
$response["success"] = 0;
$response["message"] = "No products found";

// echo no users JSON
echo json_encode($response);
 }
 }
  else {
    // required field is missing
   $response["success"] = 0;
   $response["message"] = "Required field(s) is missing";

  // echoing JSON response
  echo json_encode($response);
 }
mysql_close();
?>
4

11 回答 11

114

我也有这个错误。我通过运行修复它

mysql_upgrade -u root -p

另外,通过运行重新启动mysql服务

service mysqld restart
于 2014-01-17T20:13:01.797 回答
27

当我在 MacOS Mohave 中将 XAMPP 从 xampp-osx-7.2.10 更新到 7.3.9 时,我遇到了同样的问题。所以解决方案是:

在“Macintosh HD ▸ Applications ▸ XAMPP ▸ xamppfiles ▸ bin”中找到文件 mysql_upgrade 并双击它。

于 2019-09-23T00:21:33.340 回答
22

错误升级完成时会发生此错误。例如,如果您从 5.0 升级到 5.1 但不运行 mysql_upgrade 脚本,就会发生这种情况;或者,在极少数情况下,如果您直接从 5.0 升级到 5.5,则可能会发生这种情况。(很多人这样做,但官方不支持此类更新)您说您正在使用托管服务 - 好吧,我认为您应该创建一张票并将问题告诉他们。如果您没有 SUPER 特权,您将无能为力。但如果你有这个权利,只需运行 mysql_upgrade: http ://dev.mysql.com/doc/refman/5.1/en/mysql-upgrade.html

于 2013-04-24T00:28:59.943 回答
9

A similar error appeared in MySQL Workbench 8.0.21 after installing XAMPP 7.4.8 on Ubuntu 18.04. There were no problems using phpMyAdmin.

Error Code: 1558 Column count of mysql.proc is wrong. Expected 21, found 20. Created with MariaDB 100108, now running 100413. Please use mysql_upgrade to fix this error

Solution:

sudo /opt/lampp/lampp start
/opt/lampp/bin/mysql_upgrade

Problem solved

Credits: There appear to be a bug in XAMPP - https://community.apachefriends.org/f/viewtopic.php?f=17&t=78386&sid=3d3824dd0b6aa2e33c3adc73c744b4b4

于 2020-08-05T20:51:57.593 回答
6

当我在 Debian 8 (jessie) 中将 mysql 服务器从 5.5 更新到 5.7 时,我遇到了同样的问题。就我而言,当我执行以下命令时它运行良好:

mysql_upgrade --force -uroot -p
于 2017-08-01T09:47:52.800 回答
5

我在 Ubuntu 20.04 上使用 xampp,我的返回相同消息错误的问题已通过此解决方案解决:

  1. 进入xampp目录:cd /opt/lampp/
  2. 进入bin目录:cd bin
  3. 执行脚本:sudo ./mysql_upgrade

学分:https ://askubuntu.com/questions/1171409/how-to-run-mysql-upgrade-when-using-xampp

于 2020-10-18T03:45:31.000 回答
2

尽管您可能对升级的必要性是正确的,但这并不是发生此错误的唯一原因。

当使用返回 1 行的查询调用以下内容时

 my $rv = $sth_indexq->fetchall_arrayref;

报以下错误:

DBD::mysql::st execute failed: Column count of mysql.proc is wrong. Expected 20, found 16. Created with MySQL 50520, now running 50528. Please use mysql_upgrade to fix this error. at 
...

但是,错误的真正原因是使用了 fetchall_arrayref 而不是 fetchrow_arrayref。以下工作没有错误:

my $rv = $sth_indexq->fetchrow_arrayref;

$rv中的数据只有1 级深度,而不是 2 级

mysql_upgrade 解决方案可能很好地解决了这个问题,但简单的解决方案是了解您的数据并使用正确的检索代码。

怀特

于 2013-11-19T19:58:24.903 回答
1

点击浏览器下面的命令

/opt/lampp/bin/mysql_upgrade

于 2020-12-31T06:08:42.533 回答
1

我使用的是 Windows 10 系统,对我有用的解决方案是 mysql_upgrade -u root -p

但是您需要确保安装目录的 mysql/bin 文件夹中存在的 mysql_upgrade 脚本的路径需要添加到环境变量路径中才能使该命令正常工作

于 2020-09-23T15:57:33.317 回答
0

这发生在例如。升级而不是迁移;

它读取version check failed的部分是相关部分:

Version check failed. Got the following error when calling the 'mysql' command line client
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
FATAL ERROR: Upgrade failed

显然这是关于一个不兼容的客户端版本,但mysql数据库也不同。

这将是mysql.proc表的当前定义......它表明自 MariaDB 10.3.3 以来枚举列type已更改并且 aggregate已添加该列。

还有一个问题是:

在 MariaDB 10.4 及更高版本中,此表使用 Aria 存储引擎。

将服务器降级到 5.x 并删除 InnoDB 日志文件,然后恢复表有proc帮助;(对于 MariaDB 5.x):https ://github.com/google/mysql/blob/master/scripts/mysql_system_tables.sql

于 2022-02-08T20:44:45.530 回答
0

对于 Linux

如果您使用的是 LAMPP,那么您可以像这样修复它 -

sudo /opt/lampp/lampp start
/opt/lampp/bin/mysql_upgrade

否则,如果您单独安装了 mysql,那么您可以像这样 -

mysql_upgrade -u root -p 
service mysqld restart

对于任何其他操作系统,您可以简单地进入lampp安装的bin目录并尝试找到mysql_upgrade文件并执行它。

于 2021-09-02T13:04:16.387 回答