为了更加便捷可移动,方便管理和安装,建议使用Docker。

利用Docker管理MySQL

安装,启动

  1. docker pull mysql:latest #拉取最新版本镜像
  2. # 启动mysql容器
  3. docker run -itd --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:latest
  4. #配置好这一步即可用navicat或者数据库连接工具连接本地数据库
  5. docker ps -a # 查看运行的容器进程
  6. docker exec -it mysql bash # 进入shell
  7. mysql -uroot -p # 登录mysql

顺便记录一下docker的启动容器命令

  1. docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

OPTIONS说明:

  • -a stdin: 指定标准输入输出内容类型,可选 STDIN/STDOUT/STDERR 三项;
  • -d: 后台运行容器,并返回容器ID;
  • -i: 以交互模式运行容器,通常与 -t 同时使用;
  • -P: 随机端口映射,容器内部端口随机映射到主机的端口
  • -p: 指定端口映射,格式为:主机(宿主)端口:容器端口
  • -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
  • —name=”nginx-lb”: 为容器指定一个名称;
  • —dns 8.8.8.8: 指定容器使用的DNS服务器,默认和宿主一致;
  • —dns-search example.com: 指定容器DNS搜索域名,默认和宿主一致;
  • -h “mars”: 指定容器的hostname;
  • -e username=”ritchie”: 设置环境变量;
  • —env-file=[]: 从指定文件读入环境变量;
  • —cpuset=”0-2” or —cpuset=”0,1,2”: 绑定容器到指定CPU运行;
  • -m :设置容器使用内存最大值;
  • —net=”bridge”: 指定容器的网络连接类型,支持 bridge/host/none/container: 四种类型;
  • —link=[]: 添加链接到另一个容器;
  • —expose=[]: 开放一个端口或一组端口;
  • —volume , -v: 绑定一个卷

开始,停止,删除

  1. docker start mysql
  2. docker stop mysql
  3. docker rm mysql

一些常用的sql管理命令

当进入sql之后,命令行会变成sql状态
image.png

  1. 列出所有数据库

    1. mysql> SHOW DATABASES;
    2. +--------------------+
    3. | Database |
    4. +--------------------+
    5. | information_schema |
    6. | mysql |
    7. | performance_schema |
    8. | shici |
    9. | sys |
    10. | test |
    11. | school |
    12. +--------------------+

    其中,information_schemamysqlperformance_schemasys是系统库,不要去改动它们。其他的是用户创建的数据库。

  2. 要创建一个新数据库,使用命令:

    1. mysql> CREATE DATABASE test;
    2. Query OK, 1 row affected (0.01 sec)
  3. 要删除一个数据库,使用命令:

    1. mysql> DROP DATABASE test;
    2. Query OK, 0 rows affected (0.01 sec)
  4. 对一个数据库进行操作时,要首先将其切换为当前数据库:

    1. mysql> USE test;
    2. Database changed

    列出当前数据库的所有表,使用命令:

    1. mysql> SHOW TABLES;
    2. +---------------------+
    3. | Tables_in_test |
    4. +---------------------+
    5. | classes |
    6. | statistics |
    7. | students |
    8. | students_of_class1 |
    9. +---------------------+

    要查看一个表的结构,使用命令:

    1. mysql> DESC students;
    2. +----------+--------------+------+-----+---------+----------------+
    3. | Field | Type | Null | Key | Default | Extra |
    4. +----------+--------------+------+-----+---------+----------------+
    5. | id | bigint(20) | NO | PRI | NULL | auto_increment |
    6. | class_id | bigint(20) | NO | | NULL | |
    7. | name | varchar(100) | NO | | NULL | |
    8. | gender | varchar(1) | NO | | NULL | |
    9. | score | int(11) | NO | | NULL | |
    10. +----------+--------------+------+-----+---------+----------------+
    11. 5 rows in set (0.00 sec)

    还可以使用以下命令查看创建表的SQL语句:

    1. mysql> SHOW CREATE TABLE students;
    2. +----------+-------------------------------------------------------+
    3. | students | CREATE TABLE `students` ( |
    4. | | `id` bigint(20) NOT NULL AUTO_INCREMENT, |
    5. | | `class_id` bigint(20) NOT NULL, |
    6. | | `name` varchar(100) NOT NULL, |
    7. | | `gender` varchar(1) NOT NULL, |
    8. | | `score` int(11) NOT NULL, |
    9. | | PRIMARY KEY (`id`) |
    10. | | ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 |
    11. +----------+-------------------------------------------------------+
    12. 1 row in set (0.00 sec)

    创建表使用CREATE TABLE语句,而删除表使用DROP TABLE语句:

    1. mysql> DROP TABLE students;
    2. Query OK, 0 rows affected (0.01 sec)

    修改表就比较复杂。如果要给students表新增一列birth,使用:

    1. ALTER TABLE students ADD COLUMN birth VARCHAR(10) NOT NULL;

    要修改birth列,例如把列名改为birthday,类型改为VARCHAR(20)

    1. ALTER TABLE students CHANGE COLUMN birth birthday VARCHAR(20) NOT NULL;

    要删除列,使用:

    1. ALTER TABLE students DROP COLUMN birthday;

    退出MySQL

    使用EXIT命令退出MySQL:

    1. mysql> EXIT
    2. Bye