登录mysql数据库失败怎么办

登录mysql数据库失败怎么办,第1张

以前也用过mysql数据库(那时还是mysql3),可这样的问题还是头一次遇到。我想在开发过程中遇到这类问题的人一定不在少数,那么我们就从这次出现的问题出发来一起研究一下mysql数据库的账户添加问题。先通过控制台添加一个账户:mysql>INSERT INTO user->VALUES('%','monty',PASSWORD('some_pass'),

->'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y',

->'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y',

->'','','','',0,0,0,0)

然后,建立php程序进行登录 <html><body><h1>It works!</h1><?php

$link = mysql_connect('localhost', 'monty', 'some_pass')

if (!$link) {

die('Could not connect: ' . mysql_error())}echo 'Connected successfully'

mysql_close($link)

></body></html>但是,运行后的结果却是:

原来,在mysql的这个版本中(已经很久没有用mysql了,之前的版本没有经过测试),如果使用insert命令来增加一个账号的话,必须在添加后刷新一下特权表:mysql>INSERT INTO user ->VALUES('%','monty',PASSWORD('some_pass'),

->'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y',

->'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y',

->'','','','',0,0,0,0)

mysql>FLUSH PRIVILEGES

mysql>GRANT ALL PRIVILEGES ON *.* TO 'monty'@'localhost' ->IDENTIFIED BY 'some_pass' WITH GRANT OPTION

mysql>GRANT ALL PRIVILEGES ON *.* TO 'monty'@'%' ->IDENTIFIED BY 'some_pass' WITH GRANT OPTION

mysql>GRANT RELOAD,PROCESS ON *.* TO 'admin'@'localhost'

mysql>GRANT USAGE ON *.* TO 'dummy'@'localhost'前两个帐户名称都是monty,而且都是拥有所有权限和密码。但是两者的区别在于,第一个帐户(monty@localhost)只能通过本地登录,而第二个账户(monty@%)可以通过任意主机登录。值得注意的是,为了能够使用monty帐户在任何地方进行登录,这两个账户同时存在则是必要的。因为,如果没有本地帐户(monty@localhost),使用monty帐户登录时,mysql_install_db将优先考虑创建一个本地的匿名帐户。那么结果将是monty账户会被当作一个匿名帐户来处理。原因则在于,匿名帐户拥有一个比nonty@%账户更加具体的host字段值,从而在user表排序的时候会相对出现的更早。

上面这个表中的admin帐号则只拥有reload和process权限且没有密码,这些权限允许该帐户执行mysqladmin reload, mysqladmin refresh,mysqladmin processlist和mysqladmin flush-xxx系列命令,但是没有权限进入任何数据库。dummy帐号没有密码也没有任何权限,它只被允许从本地(localhost)登录mysql。GRANT命令允许使用USAGE来创建一个帐号却不赋予任何权限。如果你的Mysql采用的是NO_AUTO_CREATE_USER模式,那么通过命令行模式建立一个没有密码的帐号将会失败。为了解决这个问题,你可以使用IDENTIFIED BY来指定具体的密码。

不是说账号正确就其他就能访问了,MySQL分3层,你在连接层,会判断你的账号是否合法,以及是否安全!怎么判断呢,你使用客户端的账号,是否已经存在mysql.user表下面,user和host同时匹配才可以连接上哦!

select user,host from mysql.user

root@localhost [(none)]>select user,host from mysql.user

+-----------+-----------+

| user | host |

+-----------+-----------+

| William | % |

| tzf | % |

| mysql.sys | localhost |

| root | localhost |

+-----------+-----------+

4 rows in set (0.00 sec)

#你可以看看简单的MariaDB www.linuxprobe.com/chapter-18.html你看看host里面有不有你的地址。

内容都差不多。另外我个人认为使用tar安装包,不要使用rmp安装。

1、你先确定mysql存放位置,比如你放在d:\mysql

2、制作或复制一个my.ini,修改相关目录为存在的路径

3、启动cmd,开始/运行/cmd/回车

4、增加mysql服务

d:

cd

mysql

cd

bin

mysqld

--install

MySQL5

--defaults-file=D:\mysql\my.ini


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9741415.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存