以下的文章主要介绍的是linux MySQL的具体使用以及对在linux MySQL实际操作中一些值得我们注意的相关事项的描述,以下就是linux MySQL的具体使用具体方案的描述,希望在你今后的学习中会有所帮助。
MySQL的数据库存放在什么地方(陈绪)
1. 如果使用rpm包安装,应该在/var/lib/MySQL目录下,以数据库名为目录名
2. 如果源码安装在/usr/local/MySQL中,应该在/usr/local/MySQL/var中,以数据库名为目录名
5002 从linux MySQL中导出和导入数据(陈绪)
导出数据库
MySQLdump 数据库名 > 文件名
导入数据库
MySQLadmin create 数据库名
MySQL 数据库名 < 文件名
5003 忘了MySQL的root口令怎么办(陈绪)
- # service MySQL stop
- # MySQLd_safe --skip-grant-tables &
- # MySQLadmin -u user password 'newpassword''
- # MySQLadmin flush-privileges
5004 快速安装php/MySQL(陈绪)
确保使用系统自带的apache,从安装光盘中找出所有以MySQL及php-MySQL开头的rpm包,然后运行#rpm -ivh MySQL*.rpm php-MySQL*.rpm; MySQL_install_db; service MySQL start
5005 修改linux MySQL的root口令(陈绪,yejr)
大致有2种方法:
1、MySQL>MySQL -uroot -pxxx MySQL
- MySQL>update user set passwordpassword=password('new_password') where user='user';
- MySQL>flush privileges;
2、格式:MySQLadmin -u用户名 -p旧密码 password 新密码
#MySQLadmin -uroot -password ab12
注:因为开始时root没有密码,所以-p旧密码一项就可以省略了
5006 如何使用rpm方式安装MySQL(yejr)
首先下载合适的rpm包,例如下载了文件 MySQL-5.0.19-0.i386.rpm
用一下方法安装:
#rpm -ivhU MySQL-5.0.19-0.i386.rpm
通常情况下,安装完这个rpm包后,只具备有MySQLd服务功能,其它相关的client程序和开发包还需要另外安装
- #rpm -ivhU MySQL-devel-5.0.19-0.i386.rpm
- #rpm -ivhU MySQL-client-5.0.19-0.i386.rpm
5007 如何安装已经编译好了的MySQL二进制包(yejr)
首先下载合适的二进制包,例如下载了文件 MySQL-standard-4.1.13-pc-linux-gnu-i686.tar.gz
- #groupadd MySQL
- #useradd -g MySQL MySQL
- #cd /usr/local
- #tar zxf MySQL-standard-4.1.13-pc-linux-gnu-i686.tar.gz
- #ln -s MySQL-standard-4.1.13-pc-linux-gnu-i686 MySQL
- #cd MySQL
- #scripts/MySQL_install_db --user=MySQL
- #chgrp -R MySQL *
- #bin/MySQLd_safe --user=MySQL &
有什么个性化的配置,可以通过创建 /etc/my.cnf 或者 /usr/local/MySQL/data/my.cnf,增加相关的参数来实现
5008 如何自己编译MySQL(yejr)
以redhat linux 9.0为例:
下载文件 linux MySQL-4.1.13.tar.gz
- #tar zxf MySQL-4.1.13.tar.gz
- #cd MySQL-4.1.13
- #./configure --prefix=/usr/local/MySQL --enable-assembler \
- --with-MySQLd-ldflags=-all-static --localstatedir=/usr/local/MySQL/data \
- --with-unix-socket-path=/tmp/MySQL.sock --enable-assembler \
- --with-charset=complex --with-low-memory --with-mit-threads
- #make
- #make install
- #groupadd MySQL
- #useradd -g MySQL MySQL
- #chgrp -R MySQL /usr/local/MySQL/
- #/usr/local/MySQL/bin/MySQLd_safe --user=MySQL &
有什么个性化的配置,可以通过创建 /etc/my.cnf 或者 /usr/local/MySQL/data/my.cnf,增加相关的参数来实现
5009 如何登录MySQL(yejr)
使用MySQL提供的客户端工具登录
#PATH_TO_MySQL/bin/MySQL -uuser -ppassword dateabase
5010 MySQLd起来了,却无法登录,提示"/var/lib/MySQL/MySQL.sock"不存在(yejr)
这种情况大多数是因为你的MySQL是使用rpm方式安装的,它会自动寻找 /var/lib/MySQL/MySQL.sock 这个文件,
通过unix socket登录MySQL。
常见解决办法如下:
1、创建/修改文件 /etc/my.cnf,至少增加/修改一行
[MySQL]
[client]
socket = /tmp/MySQL.sock
#在这里写上你的MySQL.sock的正确位置,通常不是在 /tmp/ 下就是在 /var/lib/MySQL/ 下
2、指定IP地址,使用tcp方式连接MySQL,而不使用本地sock方式
#linux MySQL -h127.0.0.1 -uuser -ppassword
3、为 MySQL.sock 加个连接,比如说实际的MySQL.sock在 /tmp/ 下,则
# ln -s /tmp/MySQL.sock /var/lib/MySQL/MySQL.sock即可
5011 如何新增一个MySQL用户(yejr)
格式:grant select on 数据库.* to 用户名@登录主机 identified by "密码"
例1、增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入MySQL,然后键入以下命令:
MySQL>grant select,insert,update,delete on *.* to test1@"%" Identified by "abc";
但例1增加的用户是十分危险的,你想如某个人知道test1的密码,那么他就可以在internet上的任何一台电脑上登录你的MySQL数据库并对你的数据可以为所欲为了,解决办法见例2。
例2、增加一个用户test2密码为abc,让他只可以在localhost上登录,并可以对数据库mydb进行查询、插入、修改、删除的操作(localhost指本地主机,即MySQL数据库所在的那台主机),这样用户即使用知道test2的密码,他也无法从internet上直接访问数据库,只能通过linux MySQL主机上的web页来访问了。
【编辑推荐】