无法使用MySQL

时间:2016-07-15 21:48:49

标签: mysql asp.net stored-procedures windows-hosting

所以这可能有点模糊,但我遇到了一层又一层的问题。我在Google上找到的每个“修复”都给我带来了另一个问题。 无论如何,我已经购买了一个Windows托管包,以生成一个由MySQL服务器支持的asp.net应用程序。我已经习惯了MSSQL,但这应该是可行的,对于开源来说更好。

我注意到的第一个问题是我的(最近安装的)MySQL Workbench与MySQL Server 5.7的副本不允许我连接到我的数据库。表格拒绝加载,我受到欢迎:#1548 - 无法从mysql.proc加载。该表可能已损坏

从那时起,我认为“确定没问题,我只会使用网络管理工具”,在这种情况下是 phpMyadmin 。我过去没有使用过phpMyadmin的经验,但看起来还不错,并预装在这个控制面板中。我开始创建我的前5个表。这很顺利,我现在在数据库中有5个表,其中一个甚至有一些数据,我可以通过运行“SELECT * FROM Account_Type”来查看。

一切似乎都很好,所以我去创建一个我想用来测试我的应用程序的程序。只是一个程序,它将根据用户输入的tinyInt返回一个字符串。该程序如下所示:

DROP PROCEDURE IF EXISTS `getAccountTypeName`;
DELIMITER $$
CREATE PROCEDURE `getAccountTypeName`(DimAccountTypeID)
BEGIN

DECLARE DimAccountTypeID TinyINT DEFAULT 0

SELECT AccountTypeName
FROM Account_Type
WHERE AccountTypeID = DimAccountTypeID

END
$$

DELIMITER ;

对我来说似乎很好(对MS SQL更有经验),但它返回的是我自己的MySQL Workbench本地副本所犯的错误! 无法从mysql.proc加载。该表可能已损坏

我在互联网上阅读的所有内容都指出,这是我需要升级MySQL的问题....我不知道如何升级,因为我只是在控制面板中。相反,我觉得必须有其他一些问题,有数据的表格仍会显示数据,而我昨天才创建数据,我不知道其中任何一个可能会被破坏。

我尝试使用

use mysql;
show create table mysql.proc;

正如我所看到的建议,但这只会返回另一个错误:#1044 - 用户'Birdy'的访问被拒绝@'%'到数据库'mysql'(Birdy是我的用户名) 。我不知道这是否是问题的根源,但我可以运行任何其他查询sans创建过程就好了。

接下来想到的是“嘿,如果我可以让MySQL Workbench连接并工作,那么我可以忽略控制面板”。这也不是很有成效,这是我尝试运行一些升级命令:http://i.imgur.com/yG1hKrQ.png (对于那个密码,我应该使用我的Windows吗?我的MySQL Birdy用户名密码?不确定哪个......)

这里真正的问题无论如何都只是“帮助!”。问题的根源是“无法使用phpMyAdmin创建MySQL查询”,希望我的小故事可以帮助诊断。非常感谢这些问题的一些帮助:)

编辑: 我让mysql_upgrade运行但仍然没有骰子。它没有解决问题,仍然看起来像这样: http://i.imgur.com/NJpnRzw.png

编辑2: 所以我现在放弃了这个,将我的数据库切换到MSSQL并坚持我最熟悉的东西。重新安装数据库没有帮助,我的网站主机也没有升级。无论如何,谢谢你的帮助

1 个答案:

答案 0 :(得分:0)

root用户身份连接到mysql服务器,删除表proc并创建另一个:

CREATE TABLE `proc` (
  `db` char(64) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL DEFAULT '',
  `name` char(64) NOT NULL DEFAULT '',
  `type` enum('FUNCTION','PROCEDURE') NOT NULL,
  `specific_name` char(64) NOT NULL DEFAULT '',
  `language` enum('SQL') NOT NULL DEFAULT 'SQL',
  `sql_data_access` enum('CONTAINS_SQL','NO_SQL','READS_SQL_DATA','MODIFIES_SQL_DATA') NOT NULL DEFAULT 'CONTAINS_SQL',
  `is_deterministic` enum('YES','NO') NOT NULL DEFAULT 'NO',
  `security_type` enum('INVOKER','DEFINER') NOT NULL DEFAULT 'DEFINER',
  `param_list` blob NOT NULL,
  `returns` longblob NOT NULL,
  `body` longblob NOT NULL,
  `definer` char(77) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL DEFAULT '',
  `created` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  `modified` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
  `sql_mode` set('REAL_AS_FLOAT','PIPES_AS_CONCAT','ANSI_QUOTES','IGNORE_SPACE','NOT_USED','ONLY_FULL_GROUP_BY','NO_UNSIGNED_SUBTRACTION','NO_DIR_IN_CREATE','POSTGRESQL','ORACLE','MSSQL','DB2','MAXDB','NO_KEY_OPTIONS','NO_TABLE_OPTIONS','NO_FIELD_OPTIONS','MYSQL323','MYSQL40','ANSI','NO_AUTO_VALUE_ON_ZERO','NO_BACKSLASH_ESCAPES','STRICT_TRANS_TABLES','STRICT_ALL_TABLES','NO_ZERO_IN_DATE','NO_ZERO_DATE','INVALID_DATES','ERROR_FOR_DIVISION_BY_ZERO','TRADITIONAL','NO_AUTO_CREATE_USER','HIGH_NOT_PRECEDENCE','NO_ENGINE_SUBSTITUTION','PAD_CHAR_TO_FULL_LENGTH') NOT NULL DEFAULT '',
  `comment` text CHARACTER SET utf8 COLLATE utf8_bin NOT NULL,
  `character_set_client` char(32) CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL,
  `collation_connection` char(32) CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL,
  `db_collation` char(32) CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL,
  `body_utf8` longblob,
  PRIMARY KEY (`db`,`name`,`type`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='Stored Procedures'