->'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:\mysql2、制作或复制一个my.ini,修改相关目录为存在的路径
3、启动cmd,开始/运行/cmd/回车
4、增加mysql服务
d:
cd
mysql
cd
bin
mysqld
--install
MySQL5
--defaults-file=D:\mysql\my.ini
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)