mysql修改用户密码的几种方法:

方法1: 用SET PASSWORD命令
首先登录MySQL。
格式:mysql> set password for 用户名@localhost = password('新密码');
例子:mysql> set password for root@localhost = password('123');

方法2:用mysqladmin
格式:mysqladmin -u用户名 -p旧密码 password 新密码
例子:mysqladmin -uroot -p123456 password 123

方法3:用UPDATE直接编辑user表
首先登录MySQL。
mysql> use mysql;
mysql> update user set password=password('123') where user='root' and host='localhost';
mysql> flush privileges;

方法4:在忘记root密码的时候,可以这样
1.编辑vi /etc/my.cnf
2.最后一行添加mysqld --skip-grant-tables ###--skip-grant-tables 的意思是启动MySQL服务的时候跳过权限表认证。

  1. use MySQL;
  2. 改密码:update user set password=password("123") where user="root";(别忘了最后加分号) 。
  3. 刷新权限(必须步骤):flush privileges; 。

mysql 备份

1、备份命令
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 --database 数据库名 > 文件名.sql
例如: mysqldump -h 192.168.1.100 -p 3306 -uroot -ppassword --database cmdb > /data/backup/cmdb.sql

2、备份压缩
导出的数据有可能比较大,不好备份到远程,这时候就需要进行压缩
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 --database 数据库名 | gzip > 文件名.sql.gz
例如: mysqldump -h192.168.1.100 -p 3306 -uroot -ppassword --database cmdb | gzip > /data/backup/cmdb.sql.gz

3、备份同个库多个表
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 --database 数据库名 表1 表2 .... > 文件名.sql
例如 mysqldump -h192.168.1.100 -p3306 -uroot -ppassword cmdb t1 t2 > /data/backup/cmdb_t1_t2.sql

4、同时备份多个库
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 --databases 数据库名1 数据库名2 数据库名3 > 文件名.sql
例如:mysqldump -h192.168.1.100 -uroot -ppassword --databases cmdb bbs blog > /data/backup/mutil_db.sql

5、备份实例上所有的数据库
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 --all-databases > 文件名.sql
例如:mysqldump -h192.168.1.100 -p3306 -uroot -ppassword --all-databases > /data/backup/all_db.sql

6、备份数据出带删除数据库或者表的sql备份
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 --add-drop-table --add-drop-database 数据库名 > 文件名.sql
例如:mysqldump -uroot -ppassword --add-drop-table --add-drop-database cmdb > /data/backup/all_db.sql

7、备份数据库结构,不备份数据
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 --no-data 数据库名1 数据库名2 数据库名3 > 文件名.sql
例如:mysqldump --no-data –databases db1 db2 cmdb > /data/backup/structure.sql

mysql 恢复

1.方法一:
mysql -u用户名 -p密码 数据库名 < 数据库名.sql
mysql -uroot -p123456 redmine < redmine.sql

2.方法二
mysql -uroot -p ####进入数据库
use redmine; ####选择数据库
source /usr/local/src/redmine.sql;

3.如果是备份了全库的话,那下面需要恢复全库。
备份全库
mysqldump -uroot -p123456 --all-databases > /usr/local/src/all_db.sql
恢复全库
mysql -uroot -p
source /usr/local/src/redmine.sql;
注意:在恢复全库的时候不要选择数据库,不选为全部。

mysql 添加用户,删除用户和授权

方法一:添加一个test用户,密码为123456。
mysql>grant all on . to test@'127.0.0.1' identified by "123456";

方法二:增加一个用户test2密码为123456,让他只可以在localhost上登录,并可以对数据库mydb进行查询、插入、修改、删除的操作
mysql> grant select,insert,update,delete on . to test2@localhost Identified by "123456";

方法三:创建了一个名为:test 密码为:1234 的用户。
mysql> insert into mysql.user(Host,User,Password) values("localhost","test",password("1234"));
注意:此处的"localhost",是指该用户只能在本地登录,不能在另外一台机器上远程登录。如果想远程登录的话,将"localhost"改为"%",表示在任何一台电脑上都可以登录。也可以指定某台机器可以远程登录。

mysqldump -uroot -p111111 -R -E --triggers --single-transaction --master-data=2 --hex-blob --opt --databases xxxxxx >/tmp/xxxx.sql
mysql -uroot -p111111

mysql为用户授权

  1. 授权test用户拥有testDB数据库的所有权限(某个数据库的所有权限):
    mysql>grant all privileges on testDB.* to test@localhost identified by '1234';
    mysql>flush privileges;//刷新系统权限表

格式:grant 权限 on 数据库.* to 用户名@登录主机 identified by "密码"; 

2.指定部分权限给一用户,可以这样来写:
mysql>grant select,update on testDB.* to test@localhost identified by '1234';
mysql>flush privileges; //刷新系统权限表

3.授权test用户拥有所有数据库的某些权限:  
mysql>grant select,delete,update,create,drop on . to test@"%" identified by "1234";

//test用户对所有数据库都有select,delete,update,create,drop 权限。
//@"%" 表示对所有非本地主机授权,不包括localhost。(localhost地址设为127.0.0.1,如果设为真实的本地地址,不知道是否可以,没有验证。)
//对localhost授权:加上一句grant all privileges on testDB.* to test@localhost identified by '1234';即可。

删除用户

1.mysql>Delete FROM user Where User='test' and Host='localhost';
  mysql>flush privileges;
  mysql>drop database testDB; //删除用户的数据库
删除账户及权限:

drop user 用户名@'%';
drop user 用户名@ localhost;

常用命令

  1. 列出所有数据库
      mysql>show database;
  1. 切换数据库
      mysql>use '数据库名';

  2. 列出所有表
      mysql>show tables;

  3. 显示数据表结构
      mysql>describe 表名

  4. 删除数据库和数据表
      mysql>drop database 数据库名;
      mysql>drop table 数据表名;

如有错误还请大家指出,后续继续更新。。。。