我一直在使用 MySQL Workbench 创建我的数据库,但最近决定将结构导出到 phpmyadmin。
Workbench 有一个功能,您可以自动生成创建脚本,这样做时我得到以下输出:
SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0;
SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0;
SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='TRADITIONAL';
CREATE SCHEMA IF NOT EXISTS `mydb` DEFAULT CHARACTER SET latin1 COLLATE latin1_swedish_ci ;
USE `mydb` ;
-- -----------------------------------------------------
-- Table `mydb`.`User`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `mydb`.`User` ;
CREATE TABLE IF NOT EXISTS `mydb`.`User` (
`idUser` INT NOT NULL AUTO_INCREMENT ,
`Username` VARCHAR(25) NOT NULL ,
`Password` VARCHAR(25) NOT NULL ,
`Email` VARCHAR(45) NOT NULL ,
`DateJoined` DATETIME NOT NULL ,
PRIMARY KEY (`idUser`) )
ENGINE = InnoDB;
SET SQL_MODE=@OLD_SQL_MODE;
SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;
我的实际数据库要复杂得多,但我仅以此为例。所以现在我有了创建语句,我尝试将文件导入 phpmyadmin,这不起作用,并且还在 phpmyadmin 本身中运行代码。两次,我都收到此错误:
#1044 - Access denied for user 'myusername'@'localhost' to database 'mydb'
我最初认为问题是我试图在没有设置用户的情况下执行 sql。因此,我在 Workbench 中设置了一个用户,并尝试运行新的 create 语句(它也创建了我的用户和足够的角色),但我得到了同样的错误。
最后,我尝试在 phpmyadmin 中创建用户并运行初始脚本,但我一直收到相同的错误。
有人可以帮忙吗?
编辑:在实际错误消息上方,突出显示以下行:
CREATE SCHEMA IF NOT EXISTS `mydb` DEFAULT CHARACTER SET latin1 COLLATE latin1_swedish_ci;**
我尝试更改字符集,但仍然出现错误。