第4章、数据库的基本操作

标签: MySQL是怎样使用的新版


MySQL中把一些表的集合称为一个数据库MySQL服务器管理着若干个数据库,每个数据库下都可以有若干个表,画个图就是这样:

image_1c4jjlck0101k1lbq100u1ggd4ml46.png-75.7kB

展示数据库

在我们刚刚安装好MySQL的时候,它已经内建了许多数据库和表了,我们可以使用下边这个命令来看一下都有哪些数据库:

  1. SHOW DATABASES;

我自己的电脑上安装的MySQL版本是5.7.22,看一下在这个版本里内建了哪些数据库:

  1. mysql> SHOW DATABASES;
  2. +--------------------+
  3. | Database |
  4. +--------------------+
  5. | information_schema |
  6. | mysql |
  7. | performance_schema |
  8. | sys |
  9. +--------------------+
  10. 4 rows in set (0.01 sec)
  11. mysql>

可以看到,这一版本的MySQL已经为我们内建了4个数据库,这些数据库都是给MySQL自己内部使用的,如果我们想使用MySQL存放自己的数据,首先需要创建一个属于自己的数据库。

创建数据库

创建数据库的语法贼简单:

  1. CREATE DATABASE 数据库名;

来实际操作一下:

  1. mysql> CREATE DATABASE xiaohaizi;
  2. Query OK, 1 row affected (0.00 sec)
  3. mysql>

我把我的名字xiaohaizi作为了数据库名称,语句写完之后按下回车键,然后提示了一个Query OK, 1 row affected (0.00 sec)说明数据库创建成功了。然后我们再用SHOW DATABASES的命令查看一下现在有哪些数据库:

  1. mysql> SHOW DATABASES;
  2. +--------------------+
  3. | Database |
  4. +--------------------+
  5. | information_schema |
  6. | mysql |
  7. | performance_schema |
  8. | sys |
  9. | xiaohaizi |
  10. +--------------------+
  11. 5 rows in set (0.00 sec)
  12. mysql>

看到我们自己创建的数据库xiaohaizi就已经在列表里了。

IF NOT EXISTS

我们在一个数据库已经存在的情况下再使用CREATE DATABASE去创建这个数据库会产生错误:

  1. mysql> CREATE DATABASE xiaohaizi;
  2. ERROR 1007 (HY000): Can't create database 'xiaohaizi'; database exists
  3. mysql>

执行结果提示了一个ERROR,意思是数据库xiaohaizi已经存在!所以如果我们并不清楚数据库是否存在,可以使用下边的语句来创建数据库:

  1. CREATE DATABASE IF NOT EXISTS 数据库名;

这个命令的意思是如果指定的数据库不存在的话就创建它,否则什么都不做。我们试一试:

  1. mysql> CREATE DATABASE IF NOT EXISTS xiaohaizi;
  2. Query OK, 1 row affected, 1 warning (0.00 sec)
  3. mysql>

可以看到语句执行成功了,提示的ERROR也没有了,只是结果中有1个warning,这个warning只是MySQL善意的提醒我们数据库xiaohaizi已存在而已。

小贴士: warning的等级比error的等级低,如果执行某个语句后提示了warning,只是属于一个善意的提示,不影响语句的执行,而提示了error之后说明语句压根儿无法执行。

切换当前数据库

对于每一个连接到MySQL服务器的客户端,都有一个当前数据库的概念(也可以称之为默认数据库),我们创建的表默认都会被放到当前数据库中,切换当前数据库的命令也贼简单:

  1. USE 数据库名称;

在介绍表的基本操作之前,我们应该把当前数据库切换到刚刚创建的数据库xiaohaizi上:

  1. mysql> USE xiaohaizi;
  2. Database changed
  3. mysql>

看到显示了Database changed说明当前数据库已经切换成功了。需要注意的是,在退出当前客户端之后,也就是你输入了exit或者quit命令之后或者直接把当前的黑框框页面关掉,当你再次调用mysql -h 主机名 -u 用户名 -p密码的时候,相当于重新开启了一个客户端,需要重新调用USE 数据库名称的语句来选择一下当前数据库。

其实我们在新启动客户端连接服务器时就可以指定连接建立成功后客户端的当前数据库,只要把数据库名称写在启动客户端的命令mysql -h 主机名 -u 用户名 -p密码后边就好,如下:

  1. mysql -h localhost -u root -p123456 xiaohaizi

删除数据库

如果我们觉得某个数据库没用了,还可以把它删掉,语法如下:

  1. DROP DATABASE 数据库名;

在真实的工作环境里,在删除数据库之前你需要先拿体温计量量是不是发高烧了,然后再找至少两个人核实一下自己是不是发烧了,然后你才敢执行删除数据库的命令。删除数据库意味着里边的表就都被删除了,也就意味着你的数据都没了,所以是个极其危险的操作,使用时需要极其谨慎。不过我们这是学习环境,而且刚刚创建了xiaohaizi数据库,什么表都没往里头放,删了就删了吧:

  1. mysql> DROP DATABASE xiaohaizi;
  2. Query OK, 0 rows affected (0.01 sec)
  3. mysql>

然后看一下现在还有哪些数据库:

  1. mysql> SHOW DATABASES;
  2. +--------------------+
  3. | Database |
  4. +--------------------+
  5. | information_schema |
  6. | mysql |
  7. | performance_schema |
  8. | sys |
  9. +--------------------+
  10. 4 rows in set (0.01 sec)
  11. mysql>

可以看到我们前边创建的xiaohaizi数据库就没有啦。

IF EXISTS

如果某个数据库并不存在,我们仍旧调用DROP DATABASE语句去删除它,不过会报错的:

  1. mysql> DROP DATABASE xiaohaizi;
  2. ERROR 1008 (HY000): Can't drop database 'xiaohaizi'; database doesn't exist
  3. mysql>

如果想避免这种报错,可以使用这种形式的语句来删除数据库:

  1. DROP DATABASE IF EXISTS 数据库名;

再次删除一下xiaohaizi

  1. mysql> DROP DATABASE IF EXISTS xiaohaizi;
  2. Query OK, 0 rows affected, 1 warning (0.00 sec)
  3. mysql>

这回就不会报错啦!演示完删除数据库的流程之后还是把xiaohaizi数据库创建出来并且切换到当前数据库吧,毕竟我们之后还要在这个数据库里创建各种表呢~