关闭

Linux下操作Mysql

58人阅读 评论(0) 收藏 举报

原文:http://blog.csdn.net/bluestarf/article/details/19655055

三、登录MySQL


  登录MySQL的命令是mysql, mysql 的使用语法如下: 
  mysql [-u username] [-h host] [-p[password]] [dbname] 
  username 与 password 分别是 MySQL 的用户名与密码,mysql的初始管理帐号是root,没有密码,注意:这个root用户不是Linux的系统用户。MySQL默认用户是root,由于初始没有密码,第一次进时只需键入mysql即可。 
  [root@test1 local]# mysql
  Welcome to the MySQL monitor. Commands end with ; or \g.
  Your MySQL connection id is 1 to server version: 4.0.16-standard
  Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
  mysql>
  出现了“mysql>”提示符,恭喜你,安装成功!
  增加了密码后的登录格式如下:
  mysql -u root -p 
  Enter password: (输入密码)
  其中-u后跟的是用户名,-p要求输入密码,回车后在输入密码处输入密码。


  注意:这个mysql文件在/usr/bin目录下,与后面讲的启动文件/etc/init.d/mysql不是一个文件。


  四、MySQL的几个重要目录


  MySQL安装完成后不象SQL Server默认安装在一个目录,它的数据库文件、配置文件和命令文件分别在不同的目录,了解这些目录非常重要,尤其对于Linux的初学者,因为Linux本身的目录结构就比较复杂,如果搞不清楚MySQL的安装目录那就无从谈起深入学习。


  下面就介绍一下这几个目录。


  1、数据库目录
  /var/lib/mysql/


  2、配置文件
  /usr/share/mysql(mysql.server命令及配置文件)


  3、相关命令
  /usr/bin(mysqladmin mysqldump等命令)


  4、启动脚本
  /etc/rc.d/init.d/(启动脚本文件mysql的目录)
七、更改MySQL目录


  MySQL默认的数据文件存储目录为/var/lib/mysql。假如要把目录移到/home/data下需要进行下面几步:


  1、home目录下建立data目录
  cd /home
  mkdir data


  2、把MySQL服务进程停掉: 
  mysqladmin -u root -p shutdown


  3、把/var/lib/mysql整个目录移到/home/data
  mv /var/lib/mysql /home/data/
  这样就把MySQL的数据文件移动到了/home/data/mysql下 


  4、找到my.cnf配置文件
  如果/etc/目录下没有my.cnf配置文件,请到/usr/share/mysql/下找到*.cnf文件,拷贝其中一个到/etc/并改名为my.cnf)中。命令如下:
   [root@test1 mysql]# cp /usr/share/mysql/my-medium.cnf /etc/my.cnf


  5、编辑MySQL的配置文件/etc/my.cnf
  为保证MySQL能够正常工作,需要指明mysql.sock文件的产生位置。 修改socket=/var/lib/mysql/mysql.sock一行中等号右边的值为:/home/mysql/mysql.sock 。操作如下:
   vi  my.cnf    (用vi工具编辑my.cnf文件,找到下列数据修改之)
   # The MySQL server
    [mysqld]
    port   = 3306
   #socket  = /var/lib/mysql/mysql.sock(原内容,为了更稳妥用“#”注释此行)
    socket  = /home/data/mysql/mysql.sock   (加上此行)


  6、修改MySQL启动脚本/etc/rc.d/init.d/mysql
  最后,需要修改MySQL启动脚本/etc/rc.d/init.d/mysql,把其中datadir=/var/lib/mysql一行中,等号右边的路径改成你现在的实际存放路径:home/data/mysql。
  [root@test1 etc]# vi /etc/rc.d/init.d/mysql
  #datadir=/var/lib/mysql    (注释此行)
  datadir=/home/data/mysql   (加上此行)


  7、重新启动MySQL服务
  /etc/rc.d/init.d/mysql start
  或用reboot命令重启Linux
  如果工作正常移动就成功了,否则对照前面的7步再检查一下。


  八、MySQL的常用操作


  注意:MySQL中每个命令后都要以分号;结尾。


  1、显示数据库
  mysql> show databases;
  +----------+
  | Database |
  +----------+
  | mysql  |
  | test   |
  +----------+
  2 rows in set (0.04 sec)
  Mysql刚安装完有两个数据库:mysql和test。mysql库非常重要,它里面有MySQL的系统信息,我们改密码和新增用户,实际上就是用这个库中的相关表进行操作。


  2、显示数据库中的表
  mysql> use mysql; (打开库,对每个库进行操作就要打开此库,类似于foxpro )
  Database changed


  mysql> show tables;
  +-----------------+
  | Tables_in_mysql |
  +-----------------+
  | columns_priv  |
  | db       |
  | func      |
  | host      |
  | tables_priv   |
  | user      |
  +-----------------+
  6 rows in set (0.01 sec)


  3、显示数据表的结构: 
  describe 表名; 


  4、显示表中的记录: 
  select * from 表名;
  例如:显示mysql库中user表中的纪录。所有能对MySQL用户操作的用户都在此表中。
  Select * from user;


  5、建库: 
  create database 库名; 
  例如:创建一个名字位aaa的库
  mysql> create databases aaa;
6、建表: 
  use 库名; 
  create table 表名 (字段设定列表);
  例如:在刚创建的aaa库中建立表name,表中有id(序号,自动增长),xm(姓名),xb(性别),csny(出身年月)四个字段
  use aaa;
  mysql> create table name (id int(3) auto_increment not null primary key, xm char(8),xb char(2),csny date);
  可以用describe命令察看刚建立的表结构。
  mysql> describe name;


  +-------+---------+------+-----+---------+----------------+
  | Field | Type  | Null | Key | Default | Extra     |
  +-------+---------+------+-----+---------+----------------+
  | id  | int(3) |   | PRI | NULL  | auto_increment |
  | xm  | char(8) | YES |   | NULL  |        |
  | xb  | char(2) | YES |   | NULL  |        |
  | csny | date  | YES |   | NULL  |        |
  +-------+---------+------+-----+---------+----------------+


  7、增加记录
  例如:增加几条相关纪录。
  mysql> insert into name values('','张三','男','1971-10-01');
  mysql> insert into name values('','白云','女','1972-05-20');
  可用select命令来验证结果。
  mysql> select * from name;
  +----+------+------+------------+
  | id | xm  | xb  | csny    |
  +----+------+------+------------+
  | 1 | 张三 | 男  | 1971-10-01 |
  | 2 | 白云 | 女  | 1972-05-20 |
  +----+------+------+------------+


  8、修改纪录
  例如:将张三的出生年月改为1971-01-10
  mysql> update name set csny='1971-01-10' where xm='张三';


  9、删除纪录
  例如:删除张三的纪录。
  mysql> delete from name where xm='张三';


  10、删库和删表 
  drop database 库名; 
  drop table 表名; 


  九、增加MySQL用户


  格式:grant select on 数据库.* to 用户名@登录主机 identified by "密码" 
例1、增加一个用户user_1密码为123,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入MySQL,然后键入以下命令: 


  mysql> grant select,insert,update,delete on *.* to user_1@"%" Identified by "123"; 
例1增加的用户是十分危险的,如果知道了user_1的密码,那么他就可以在网上的任何一台电脑上登录你的MySQL数据库并对你的数据为所欲为了,解决办法见例2。 


  例2、增加一个用户user_2密码为123,让此用户只可以在localhost上登录,并可以对数据库aaa进行查询、插入、修改、删除的操作(localhost指本地主机,即MySQL数据库所在的那台主机),这样用户即使用知道user_2的密码,他也无法从网上直接访问数据库,只能通过MYSQL主机来操作aaa库。 


  mysql>grant select,insert,update,delete on aaa.* to user_2@localhost identified by "123"; 


  用新增的用户如果登录不了MySQL,在登录时用如下命令:


  mysql -u user_1 -p -h 192.168.113.50 (-h后跟的是要登录主机的ip地址)


        添加完mysql用户之后刷新权限

       flush privileges;



  十、备份与恢复


  1、备份


  例如:将上例创建的aaa库备份到文件back_aaa中


  [root@test1 root]# cd /home/data/mysql (进入到库目录,本例库已由val/lib/mysql转到/home/data/mysql,见上述第七部分内容)
  [root@test1 mysql]# mysqldump -u root -p --opt aaa > back_aaa


  2、恢复


  [root@test mysql]# mysql -u root -p ccc < back_aaa












启动mysql


/data0/mysql/3306/mysql start
登陆mysql
/usr/local/webserver/mysql/bin/mysql -u root -p -S /tmp/mysql.sock




开机自动运行mysql


进入mysql 的安装目录, 将子目录support-files下的mysql.server文件复制到/etc/rc.d/init.d目录中,并重命名为mysqld
修改 /etc/rc.d/init.d/mysqld的权限为755
使用chkconfig命令设置在不同系统下的自启策略。
首先使用 chkconfig --add mysqld 
然后使用 chkconfig --level 3 mysqld on chkconfig --level 5 mysqld on命令在第三,五等级中开机自动开启mysql服务


最后用chkconfig --list mysqld 查询设置




退出mysql客户端
输入命令“exit”或者“quit”或者按键盘 “ctrl+c”




Linux下访问window下的数据库出现1130错误,
解决:在window下进入mysql


授权GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root';


Grant授权用户,% 通配符表示对所有的访问ip有权限


出现1042错误:将linux中mysql下的my.cnf中skip-name-resolve注释
出现2003错误:关闭linux防火墙




-- DBA操作
-- 备份
-- 还原




-- 备份  
-- 语法:./mysqldump -h192.168.1.5 -u root -proot 数据库名 >路径/文件名.sql
-- 步骤:
-- 1.cmd
-- 2.cd mysql/bin 进入mysql的bin目录
-- 3.执行mysqldump -u root -p 数据库名 >路径/文件名.sql             school
-- 例如:执行mysqldump -u root -p mydb >1111.sql 
-- 意思是导出用户名为root需要密码的一个数据库名叫mydb的数据库里的所有数据以及表结构到1111.sql文件中 
-- 输入root的密码
-- 例如:Enter password: **** 




-- 还原
-- 语法:mysql -u root -p 数据库名< 路径/文件名.sql 
-- 1.新建数据库
-- 2.mysql -u root -p 数据库名< 路径/文件名.sql 
-- 还原数据库,在当前目录下 在执行例如: 
-- C:\Program Files\MySQL\bin>mysql -u root -p mydb< c:/1111.sql 


Enter password: **** 




create database aaa




-- 导入脚本
-- XXX.sql
-- 打开数据库,才能导入脚本文件
-- 语法:mysql> \. 路径/文件.sql
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:5401次
    • 积分:379
    • 等级:
    • 排名:千里之外
    • 原创:33篇
    • 转载:8篇
    • 译文:0篇
    • 评论:0条