1. DDL(数据定义语言)
DDL(Data Definition Language
),数据定义语言,用来定义数据库对象(数据库,表,字段) 。
1.1 数据库操作
1.1.1 查询所有数据库
SHOW DATABASES;
1.1.2 查询当前数据库
SELECT DATABASE();
1.1.3 创建数据库
create database [ if not exists ] 数据库名
[ default charset 字符集 ] [ collate 排序 规则 ] ;
# 提示:`` 符号可以不加
CREATE DATABASE `tianjiao`;
运行结果:
说明:在同一个数据库服务器中,不能创建两个名称相同的数据库,否则将会报错。
可以通过 if not exists
参数来解决这个问题,数据库不存在, 则创建该数据库,如果存在,则不创建。
CREATE DATABASE IF NOT EXISTS `tianjiao`;
/*
不推荐使用 utf8 因为uft8字符集存储的长度为3字节,
但是数据中有些特殊的字符是4字节的,
所以我们推荐使用utf8mb4字符集(支持4字节)
*/
CREATE DATABASE `codejiao` DEFAULT CHARSET utf8mb4;
运行结果:
1.1.4 删除数据库
drop database [ if exists ] 数据库名 ;
如果删除一个不存在的数据库,将会报错。此时,可以加上参数 if exists
,如果数据库存在,再执行删除,否则不执行删除。
1.1.5 切换数据库
use 数据库名 ;
我们要操作某一个数据库下的表时,就需要通过该指令,切换到对应的数据库下,否则是不能操作的。比如,切换到codejiao
数据,执行SQL
:
USE codejiao
1.2 表操作
1.2.1 查询当前数据库所有表
show tables;
比如,我们可以切换到sys
这个系统数据库,并查看系统数据库中的所有表结构。
1.2.2 查看指定表结构
通过这条指令,我们可以查看到指定表的字段,字段的类型、是否可以为NULL
,是否存在默认值等信息。
息。
desc 表名;
我们先创建一个表作为演示:
/*
目标:创建学生表,使用SQL创建
学号int,登录密码varchar(20) 姓名,性别varchar(3),出生日期(datetime)
家庭住址,email
注意点:使用英文(),表的名称和字段尽量用``.括起来
AUTO_INCREMENT 自增
所有字符串都使用""括起来
所有语句后面加上, 最后一个字段不用加,
COMMENT 注释
PRIMARY KEY(`id`) 主键 ,一般一个表只有一个主键
*/
CREATE TABLE IF NOT EXISTS `student`(
`id` INT(4) NOT NULL AUTO_INCREMENT COMMENT "学号",
`name` VARCHAR(3) NOT NULL DEFAULT "匿名" COMMENT "姓名",
`psd` VARCHAR(20) NOT NULL DEFAULT "123456" COMMENT "密码",
`sex` VARCHAR(2) NOT NULL DEFAULT "男" COMMENT "性别",
`birthday` DATETIME DEFAULT NULL COMMENT "出生日期",
`address` VARCHAR(100) DEFAULT NULL COMMENT "家庭住址",
`email` VARCHAR(30) DEFAULT NULL COMMENT "邮箱",
PRIMARY KEY(`id`)
)ENGINE =INNODB DEFAULT CHARSET=utf8;
运行结果:
查询该表的表结构:
1.2.3 查询指定表的建表语句
通过这条指令,主要是用来查看建表语句的,而有部分参数我们在创建表的时候,并未指定也会查询到,因为这部分是数据库的默认值,如:存储引擎、字符集等。
show create table 表名 ;
我们把下划线的内容粘贴出来:
CREATE TABLE `student` (
`id` int NOT NULL AUTO_INCREMENT COMMENT '学号',
`name` varchar(3) NOT NULL DEFAULT '匿名' COMMENT '姓名',
`psd` varchar(20) NOT NULL DEFAULT '123456' COMMENT '密码',
`sex` varchar(2) NOT NULL DEFAULT '男' COMMENT '性别',
`birthday` datetime DEFAULT NULL COMMENT '出生日期',
`address` varchar(100) DEFAULT NULL COMMENT '家庭住址',
`email` varchar(30) DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3;
1.2.4 创建表
注意: [...]
内为可选参数,最后一个字段后面没有逗号。
比如,我们创建一张表 tb_user
,对应的结构如下,那么建表语句为:
CREATE TABLE tb_user (
id INT COMMENT '编号',
NAME VARCHAR ( 50 ) COMMENT '姓名',
age INT COMMENT '年龄',
gender VARCHAR ( 1 ) COMMENT '性别' ) COMMENT '用户表';