数据库概述
- 什么是数据库
数据库就是存储数据的仓库,其本质是一个文件系统,数据按照特定的格式将数据存储起来,用户可以对数据库中的数据进行增加,修改,删除及查询操作。
- 什么是数据库管理系统
数据库管理系统(DataBase Management System,DBMS):指一种操作和管理数据库的大型软件,用于建立、使用和维护数据库,对数据库进行统一管理和控制,以保证数据库的安全性和完整性。用户通过数据库管理系统访问数据库中表内的数据。
SQL语句
结构化查询语言(Structured Query Language)简称SQL,是关系型数据库管理系统都需要遵循的规范。不同的数据库生产厂商都支持SQL语句,但都有特有内容。即大家说的数据库方言。
SQL语句分类
- 数据定义语言:
简称DDL(Data Definition Language),用来定义数据库对象:数据库,表,列等。关键字:create,alter,drop等
- 数据操作语言
简称DML(Data Manipulation Language),用来对数据库中表的记录进行更新。关键字:insert,delete,update等
- 数据控制语言
简称DCL(Data Control Language),用来定义数据库的访问权限和安全级别,及创建用户。
- 数据查询语言
简称DQL(Data Query Language),用来查询数据库中表的记录。关键字:select,from,where,group by, order by ,having等
SQL通用语法
SQL通用语法:
1.SQL语句可以单行或多行书写,以分号结尾
2.可使用空格和缩进来增强语句的可读性
3.MySQL数据库的SQL语句不区分大小写,关键字建议使用大写
4.同样可以使用/**/的方式完成注释
MySQL中的我们常使用的数据类型如下:
了解详情请访问:SQL数据类型
DDL之数据库操作
1.创建数据库
格式:
create database 数据库名;
create database 数据库名 character set 字符集;
例如:
#创建数据库 数据库中数据的编码采用的是安装数据库时指定的默认编码 utf8
CREATE DATABASE webdb_1;
#创建数据库 并指定数据库中数据的编码
CREATE DATABASE webdb_2 CHARACTER SET utf8;
- 查看数据库
格式:
show databases;(查看当前所有数据库)
查看某个特定的数据库:
show create database 数据库名;
例如:
show create database webdb_1; - 删除数据库
格式:
drop database 数据库名称;
例如:
drop database webdb_2; - 使用数据库
查看正在使用的数据库:
格式:
select database();
.切换数据库:
use 数据库名;
例如:
use webdb_1;
DDL之表操作
- 创建表
格式:
create table 表名(
字段名 类型(长度) [约束],
字段名 类型(长度) [约束],
...
);
类型: varchar(n) 字符串
int 整形
double 浮点 d
ate 时间
timestamp 时间戳
约束:(后面详解)primary key 主键,被主键修饰字段中的数据,不能重复、不能为null。
例如:
###创建分类表
CREATE TABLE category (
cid INT primary key, #分类ID
cname VARCHAR(100) #分类名称
);
- 查看表
查看数据库中的所有表:
格式:show tables;
查看表结构:
格式:desc 表名;
例如:desc category;
-
删除表
格式:drop table 表名;
例如:drop table category; -
修改表结构格式
- 修改表添加列
格式:alter table 表名 add 列名 类型(长度) [约束];
#1,为分类表添加一个新的字段为 分类描述 varchar(20)
ALTER TABLE category ADD `desc` VARCHAR(20);
- 修改表修改列的类型长度及约束.
格式:alter table 表名 modify 列名 类型(长度) 约束;
#2, 为分类表的描述字段进行修改,类型varchar(50) 添加约束 not null
ALTER TABLE category MODIFY `desc` VARCHAR(50) NOT NULL;
注意:如果有数据,必须注意数据类型varchar–>int 容易有错误数据,需修改可转换的数据方可执行
- 修改表修改列名.
格式:alter table 表名 change 旧列名 新列名 类型(长度) 约束;
#3, 为分类表的分类名称字段进行更换 更换为 description varchar(30)
ALTER TABLE category CHANGE `desc`description VARCHAR(30);
- 修改表删除列.
格式:alter table 表名 drop 列名;
#4, 删除分类表中description这列
ALTER TABLE category DROP description;
注意: 如果列中有数据,数据就会一起删除了,需谨慎
- 修改表名
格式:rename table 表名 to 新表名;
#5, 为分类表category 改名成 category2
RENAME TABLE category TO category2;
- 修改表的字符集
格式:alter table 表名 character set 字符集
#6, 为分类表 category 的编码表进行修改,修改成 gbk
ALTER TABLE category CHARACTER SET gbk;
注意:不建议执行,可能出现乱码
DML数据操作语言
即为开发中常使用的insert,update,delete语句。
- 插入表记录:insert
语法:
-- 向表中插入某些字段
insert into 表 (字段1,字段2,字段3..) values (值1,值2,值3..);
--向表中插入所有字段,字段的顺序为创建表时的顺序
insert into 表 values (值1,值2,值3..);
注意:
值与字段必须对应,个数相同,类型相同,顺序相同
值的数据大小必须在字段的长度范围内
除了数值类型外,其它的字段类型的值必须使用引号引起。(建议单引号)
如果要插入空值,可以不写字段,或者插入 null
- 更新表记录:update
语法:
--更新所有记录的指定字段
update 表名 set 字段名=值,字段名=值,...;
--更新符合条件记录的指定字段
update 表名 set 字段名=值,字段名=值,... where 条件过滤;
注意:
列名的类型与修改的值要一致.
修改值得时候不能超过最大长度.
除了数值类型外,其它的字段类型的值必须使用引号引起
- 删除记录:delete
语法格式:
delete from 表名 [where 条件];
或者
truncate table 表名;
注意:
删除表中所有记录使用delete from 表名; 还是用truncate table 表名; 删除方式:
delete一条一条删除,不清空auto_increment记录数。
truncate直接将表删除,重新建表,auto_increment将置为零,从新开始。