我有这个 php 函数:
function createDatabase($dbName,$dbPass) {
$host = 'localhost';
$user = 'myuser';
$user_password = 'mypass';
$db = new PDO("mysql:host=$host", $user, $user_password);
$db->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );
try {
doLog('Creating Database...');
$count = $db->exec("CREATE DATABASE `$dbName`");
if($count === false) {
doLog('Could not create database');
return false;
}
doLog('Creating User...');
$count = $db->exec("CREATE USER '$dbName'@'localhost' IDENTIFIED BY '$dbPass'");
if($count === false) {
doLog('Could not create user');
return false;
}
doLog('Granting User Privileges...');
$count = $db->exec("GRANT ALL ON `$dbName`.* TO '$dbName'@'localhost'");
if($count === false) {
doLog('Could not grant user privileges');
return false;
}
doLog('Flushing Privileges...');
$count = $db->exec("FLUSH PRIVILEGES");
if($count === false) {
doLog('Could not flush privileges');
return false;
}
} catch (PDOException $e) {
doLog("DB ERROR: ". $e->getMessage());
return false;
}
return true;
}
我正在这里解决另一个问题: Can I create a database using PDO in PHP
此代码在第三次查询期间一直挂起,并授予权限并出现以下错误:
SQLSTATE[42000]: Syntax error or access violation: 1044 Access denied for user
相关 MySQL 用户拥有全局权限,包括 grant。我还能错过什么?
最佳答案
The MySQL user in question has global permissions, including grant. What else could I be missing?
注意到但常识。
如果您的数据库显示用户没有权限那么事实就是如此。
这就是错误消息的要点:您必须阅读它们并修复它们。就这么简单。
关于PHP PDO 创建MySQL数据库和用户并授予权限,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38154173/