mysql安装完成后一般密码都为空,需要初始化密码,具体命令如下:
mysql> /usr/local/mysql/bin/mysqladmin -u root password 'xxx'
mysql> SELECT USER,HOST,PASSWORD FROM mysql.user;
mysql> use mysql;
mysql> update user set password=password("xxxx") where user="root";
mysql> delete from user where User="" and Host="localhost";
mysql> delete from user where User="" and Host="localhost.localdomain";
mysql> grant all privileges on *.* to 'test'@'%' identified by 'xxxx';
mysql> flush privileges;
mysql> SELECT USER,HOST,PASSWORD FROM mysql.user;
查看mysql用户
mysql> select user,host,password from mysql.user;
查看用户权限
mysql> show grants for root@localhost;
mysql密码破解:
在my.cnf中加入 skip-grant-tables,然后重启mysql,
进入修改用户密码:
mysql>use mysql
mysql>update user setpassword=password("new_pass") where user="root";
修改完了删除my.cnf中的skip配置,再重启mysql
PS:update user set host ='%' where user = 'root';可以让任何用户访问,不仅仅只有本地用户
mysql导入导出及备份:
1.导出整个数据库
mysqldump -u 用户名 -p 数据库名 > 导出的文件名
mysqldump -u wcnc -p smgp_apps_wcnc > wcnc.sql
2.导出一个表
mysqldump -u 用户名 -p 数据库名表名> 导出的文件名
mysqldump -u wcnc -p smgp_apps_wcncusers> wcnc_users.sql
把密码写到脚本里面会提示:
Warning: Using a password on the command line interfacecan be insecure.接口可以不安全
3.导出一个数据库结构(desc看到的表的结构)
mysqldump -u wcnc -p -d --add-drop-table smgp_apps_wcnc >d:wcnc_db.sql
-d 没有数据 --add-drop-table 在每个create语句之前增加一个drop table
4.如果需要导出mysql里面的函数或者存储过程
mysqldump -hhostname -uusername -ppassword -ntd -R databasename > backupflie.sql
mysqldump -hlocalhost -uroot -ntd -R hqgr > hqgr.sql 或者
mysqldump -hlocalhost -uroot -R hqgr > hqgr.sql
其中的 -ntd 是表示导出存储过程;-R是表示导出函数
常用source 命令:
进入mysql数据库控制台,
如mysql -u root -p
mysql>use 数据库
然后使用source命令,后面参数为脚本文件(如这里用到的.sql)
mysql>source d:wcnc_db.sql
mysql 导入:
mysql -hhostname -uusername -ppassword databasename < backupfile.sql
eg:[root@localhost ~]#/usr/local/mysql/bin/mysqldump -h localhost -utest -p xx > xx.sql
删除数据库:
mysql> drop databasetest;
Query OK, 49 rows affected (1.84 sec)
重建库和表
用mysqldump --no-data把建表SQL导出来,然后drop database再create database,执行一下导出的SQL文件,把表建上;
删除表
mysql>drop TABLE MYTABLE;
清空表
mysql>delete from MYTABLE;
DELETE FROMtable1
开启mysql日志
[root@localhost log]#/usr/local/mysql/bin/mysql -V
/usr/local/mysql/bin/mysql Ver 14.14 Distrib 5.1.39, for pc-linux-gnu (i686)using readline 5.1,配置方法:
long_query_time = 2,单位是s
查看慢日志相关信息:
mysql> show variables like'long_query_time';
mysql> show status like 'slow_queries';
5.6 日志配置方法:mysql 5.6开启慢日志
#log
general_log = on
general_log_file = /usr/local/mysql/log/mysql.log
slow_query_log = on
slow_query_log_file =/usr/local/mysql/log/mysql-slow.log
long_query_time = 2 单位是s
#log=/usr/local/mysql/log/mysql.log
#long_query_time=2
#log_slow_queries=/usr/local/mysql/log/slowquery.log
PS:memcache启动命令:
memcached -d -p 11211 -u root -m 1024 -c 1024 -P /var/run/memcached.pid