数据库是长期存储在计算机内,有组织的和可共享的数据集合,简而言之,数据库就是一个存储数据的地方,只是在其存储方式有特定的规律,这样做可以方便处理数据,数据库的操作包括创建数据库和删除数据库,还有数据库中的查询与修改,这些操作都是数据库管理的基础。

一,创建数据库
  创建数据库是指在数据库系统中划分一块空间,用来存储相应的数据,这是进行表操作的基础,也是进行数据库管理的基础,在mysql中创建数据库需要通过SQL语句CREATE DATABASES实现,语法形式如下:

CREATE DATABASE 数据库名;

其中,‘数据库名’参数表示所要创建的数据库的名称,在创建数据库之前,可以使用SHOW语句来查看现在已经存在的数据库,语法形式如下:


SHOW DATABASE;

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| liuyandb           |
| mysql              |
| performance_schema |
| python             |
| sys                |
+--------------------+
6 rows in set (0.00 sec)

mysql>

二,删除数据库

  删除数据库是指数据库系统中删除已经存在的数据库,删除数据库之后,原来分配的空间将被回收,值得注意的是,删除数据库会删除数据库中所有的表和所有数据。

删除数据库是通过SQL语句 DROP DATABSE实现的,其语法格式如下/;.
DROP DATABASE 数据库名;

举例说明

创建一个叫做mybook的数据库,查询然后在将其删除查看:

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| liuyandb           |
| mysql              |
| performance_schema |
| python             |
| sys                |
+--------------------+
6 rows in set (0.00 sec)

mysql> create database mybook;
Query OK, 1 row affected (0.04 sec)

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| liuyandb           |
| mybook             |
| mysql              |
| performance_schema |
| python             |
| sys                |
+--------------------+
7 rows in set (0.00 sec)

mysql> drop database mybook;
Query OK, 0 rows affected (0.00 sec)

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| liuyandb           |
| mysql              |
| performance_schema |
| python             |
| sys                |
+--------------------+
6 rows in set (0.01 sec)

mysql>

三:创建,修改和删除表

  表是数据库存储数据的基本单位,一个表包含若干字段或记录,表的操作包括创建表,修改表和删除表,这些操作都是数据库管理中最基本也是最重要的操作。

3.1创建表

MySQL中创建表是通过SQL语句CREATE TABLE 实现的,其语法格式如下:

USE 数据库名
CREATE TABLE 表名(属性名  数据类型【完整约束条件】,
                                属性名  数据类型【完整约束条件】,
                                .
                                .
                                );

其中 USE数据库名表示使用某个数据库,‘表名’参数表示所要创建的表的名称 ;
‘属性名’参数表示表中字段的名称;
‘数据类型’参数指定字段的数据类型,
‘完整性约束条件’参数指定字段的某些特殊约束条件   


注:在使用create table 语句创建表时,首先使用USE语句选择数据库,选择数据库语句的基本格式为‘USE 数据库名’,如果没有选择数据库,创建表时会出现‘ERROR 1046(3D000):No DATABASE SELECTED’的错误。

表名不能使用SQL语言的关键字,如create,updata和order等都不能做表名,一个表中可以有一个或多个属性,定义时字母大小写均可,各属性之间用逗号隔开,最后一个属性后面不需要加逗号。

 注:完整性约束条件是对字段进行限制,要求用户对该属性进行操作符合特定的要求,如果不满足完整性约束条件,数据库系统将不执行用户的操作,其目的是为了保证数据库中的数据完整性,下表为完整性约束条件:

MySQL学习——操作数据库(增删改查)(一)-冯金伟博客园

例子:创建一个名为example0的表:

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| liuyandb           |
| mysql              |
| performance_schema |
| python             |
| sys                |
+--------------------+
6 rows in set (0.00 sec)

mysql> create database text;
Query OK, 1 row affected (0.01 sec)

mysql> use text;
Database changed
mysql> create table example0(id int,
    -> name varchar(20),
    -> sex boolean
    -> );
Query OK, 0 rows affected (0.34 sec)

mysql> desc example0;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    | int(11)     | YES  |     | NULL    |       |
| name  | varchar(20) | YES  |     | NULL    |       |
| sex   | tinyint(1)  | YES  |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+
3 rows in set (0.01 sec)

mysql>

注:相关概念:

主键是表的一个特殊字段,该字段能够唯一的标识该表中的每条信息,主键和记录的关系,如同身份证和人的关系,主键用来标识每个记录,每个记录的主键值都不相同,身份证是用来表名人的身份,每个人都具有唯一的身份证号,设置表的主键指在创建表时设置表的某个字段为该表的主键。

1.单字段主键

    主键是由一个字段构成时,可以直接在该字段的后面加上PRIMARY KEY 来设置主键,语法规则如下:
    属性名  数据类型  PRIMARY KEY
其中‘属性名’参数表示表中字段的名称,‘数据类型’参数指定字段的数据类型。

例:在example1表中设置stu_id作为主键,SQL代码如下:


mysql> create table example1(stu_id int primary key,
    -> stu_name varchar(20),
    -> stu_sex boolean
    -> );
Query OK, 0 rows affected (0.33 sec)

mysql> desc example1;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| stu_id   | int(11)     | NO   | PRI | NULL    |       |
| stu_name | varchar(20) | YES  |     | NULL    |       |
| stu_sex  | tinyint(1)  | YES  |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

mysql>
2.多字段主键
    主键是由多个属性组合而成时,在属性定义完之后统一设置主键,语法规则如下:

PRIMARY KEY(属性1,属性2。。。。属性n)

例:在example2表中设置stu_id与course_id俩个字段为主键,SQL代码如下:

mysql>
mysql> create table example2(stu_id int,
    -> course_id int,
    -> grade float,
    -> primary key(stu_id,course_id)
    -> );
Query OK, 0 rows affected (0.43 sec)

mysql> desc example2;
+-----------+---------+------+-----+---------+-------+
| Field     | Type    | Null | Key | Default | Extra |
+-----------+---------+------+-----+---------+-------+
| stu_id    | int(11) | NO   | PRI | NULL    |       |
| course_id | int(11) | NO   | PRI | NULL    |       |
| grade     | float   | YES  |     | NULL    |       |
+-----------+---------+------+-----+---------+-------+
3 rows in set (0.00 sec)

mysql>

查看表基本结构语句(DESCRIBE)

  DESCRIBE 表名;或者 DESC 表名

查看表详细结构语句 SHOW CREATE TABLE

  SHOW CREATE TABLE example1G

例子:

mysql>
mysql> desc example1;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| stu_id   | int(11)     | NO   | PRI | NULL    |       |
| stu_name | varchar(20) | YES  |     | NULL    |       |
| stu_sex  | tinyint(1)  | YES  |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

mysql> show create table example1G
*************************** 1. row ***************************
       Table: example1
Create Table: CREATE TABLE `example1` (
  `stu_id` int(11) NOT NULL,
  `stu_name` varchar(20) DEFAULT NULL,
  `stu_sex` tinyint(1) DEFAULT NULL,
  PRIMARY KEY (`stu_id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1
1 row in set (0.00 sec)

mysql>