作者 : D. Star.
专栏 : JAVA
今日提问 : 你好,我的朋友,在你的人生途中,会面临很多选择,不管选什么样的结果,我们都多少会有些后悔。如果是你,你会选择爱你的,还是懂你的?
Oracle(最好),Mysql(最广泛–免费),SQL Server(好用不火),SQLite(轻量级)
MongoDB,Redis,HBase
数据库(Database)是按照数据结构来组织、存储和管理数据的仓库。
表是数据的矩阵。在一个数据库中的表看起来像一个简单的电子表格。
一列(数据元素) :包含了相同的数据。
一行(元组/记录):是一组相关的数据。
主键是唯一的。一个数据表中只能包含一个主键。
外键用于关联两个表。
create database 表名(列名 类型,…);
例如:创建一个名为student的数据库
//eg:创建一个名为student的数据库
create database student;
drop database 表名;
例如:删除一个名为student的数据库
//eg:删除一个名为student的数据库
drop database student;
show databases;
show databases;//显示所有数据库
create table 表名(列名 类型,…);
例如:创建一个名为stu的数据表(id,姓名,成绩);
//eg:创建一个名为student的数据表(id,姓名,成绩)
create table student(id int,name varchar(20),grade decimal(3,1));
drop table 表名;
例如:删除一个名为student的数据表;
//eg:删除一个名为student的数据表
drop table stu;
show tables;
desc 【表名】;
例如:展示stu数据库里的所有表名:
//eg:展示stu数据库里的所有表名:
show tables;
例如:查看books表的结构
desc books;
alter table 【表名】 drop【列名】;
例如:删除student表中的grade列
//eg:删除student表中的grade列
alter table student drop grade;
alter table 【表名】 add【列名】 【类型】;
例如:增加student表中的grade列
//eg:增加student表中的grade列
alter table student add grade decimal(3,1);
- 修改列的名字
alter table【表名】 change【列名】【新名】 ;
例如:将student表中的grade改为成绩
//eg:将student表中的grade改为成绩
alter table student change grade '成绩';
- 创建索引
alter table 【表名】 add index 索引名(列名);
例如:创建student表中的名字为索引
//eg:创建student表中的名字为索引
alter table student add index index_name(name);
alter table 【表名】 drop index 索引名(列名);
例如:删除student表中的名字为索引
//eg:删除student表中的名字为索引
alter table student drop index index_name(name);
alter table 【表名】 rename 【新表名】;
例如:将student表的表名改成students
//eg:将student表的表名改成students
alter table student rename students;
(否则无法进行该数据库的操作)
use 数据库名;
例如:假设这里的数据库名位stu;
//eg:假设这里的数据库名位stu;
use stu;
- 直接增加一条/多条记录 。
insert into 【表名】 values(…);
insert into 【表名】 values(…),(…),(…);
例如:在students表中插入(1,‘王五’,85.5);
注 : varchar类型可以是单引号/双引号
//eg:在students表中插入(1,'王五',85.5);
//法一:
insert into students values(1,'王五',85.5);
insert into students values(1,"王五",85.5);
//法二:
insert into students(name,id,grade) values('王五',1,85.5);
- 插入特定数据(select挑选出来的)。
insert into stutends(name,grade) (select name,grade from students where id = 1);
例如:将students表中id为1的(姓名,成绩)插入到students表中新的(姓名成绩)
eg:将students表中id为1的(姓名,成绩)插入到students表中新的(姓名成绩)
insert into stutends(name,grade) (select name,grade from students where id = 1);
- 删除表中的一条或者多条记录。
delete from 【表名】 where 【条件】;
delete from 【表名】;
//(删除的是符合该条件的一条条记录)
//eg:删除成绩为0的记录
delete from students where grade = 0;
//(删除全部数据)
delete from students;
- 查询全部列。
select * from 【表名】 where 【条件】;
例如:查询students中成绩大于50的全部学生信息
//eg:查询students中成绩大于50的全部学生信息
select * from students where grade>50;
- 查询个别列。
select 【列名】 from 【表名】where 【条件】;
例如:查询students中成绩大于50的学生姓名
//eg:查询students中成绩大于50的学生姓名
select name from students where grade>50;
- 根据筛选条件,将原字段改为新内容。
update 【表名】set 【字段名】=【新内容】 where 【条件】;
例如:将students表中序号为1的学生的成绩改为97;
//eg:将students表中序号为1的学生的成绩改为97;
update students set grade = 97 where id = 1;
提问:一个汉字在JAVA(utf8)中占几个字节?
答:3bit/字。
(提前)结论:所有的查询条件产生的只是一个结果集,不会影响内存里的数据
含义 : 重命名(表面的,不影响内存里的数据)[下面有证明图片]
注意:只针对一个字段重命名
公式①:select 【字段 as 【重命名】,…】 from 【表名】
公式② select 【… , 字段】 as 【重命名】 from 【表名】
例如:将books中的id显示为序号
//eg:将books中的id显示为序号
//法一:
select id as '序号',name,author,price,kinds,year from books;
//法二:
select name,author,price,kinds,year,id as '序号' from books;
含义 : 去重(将字段中重复的部分去掉)
并且只能放在字段前面
例如 : 显示books中的year(去重)
//eg : 显示books中的year(去重)
select distinct year from books;
如果distinct后面接了很多的字段,那就将这些字段作为一组字段,并且显示不重复的组字段.
根据特定条件/字段排序
默认是升序[asc]
也可以在后面加上desc(降序)
注意!!!可识别别名
例如 : 在books表中,按照price的高低排序
//eg: 在books表中,按照price的高低排序
select * from books order by price;
% : 代表0个字符或者N个字符
格式: like ‘%xxx’
_ : 代表一个字符
格式: like ‘_xxx’
注意: like前面可以加not 表示否定.
注意: like 后面一定要加 ’ ’ 或者 " " ;
表示的是一个范围区间,前闭后闭
between前面可以加not
例如: 在books表中,找出价格在[50,500]之间的书
//eg: 在books表中,找出价格在[50,500]之间的书
select * from books where price between 50 and 500;
作为条件: 且,或
例如: 在books表中,找出价格大于100并且(可换成或者)在2000以后发行的书
//eg:在books表中,找出价格大于100并且在2000以后发行的书
select * from books where price > 100 and year > 2000;
作为数值挑选项
例如: 在books表中,找出价格是50或者500之间的书
//eg:在books表中,找出价格是50或者500之间的书
select * from books where price in(50,500);
<==> : 严格比较两个NULL值是否相等
例如: 找出books表中,author为NULL的信息;
select * from books where author <=> null;
limit + 数字 : 分页查询(默认从下表为0的数据开始展示)
offset + 数字 : 声明从哪一条开始查询(默认从0开始)
例如: 显示books表中的3条数据;
//eg:显示books表中的3条数据;
select * from books limit 3;
例如: 显示books表中的3条数据并从第二条数据开始(即下表为1的数据);
//eg:显示books表中的3条数据并从第二条数据开始(即下表为1的数据);
select * from books limit 3 offset 1;
作用 : 分组,将列值相同的分到一组
注意 : 分组后 , 取(显示)的是第一行数据
例如:显示出一班和二班的总成绩是多少?
select class,sum(score) from student group by class;
分组前筛选用where
例如 : 通过班级分组显示分数>60的数据
select * from student where score>60 group by class;
注意!!!where无法识别select 到 from 之间的别名,但是可以识别from后的
分组后筛选用having
例如 : 通过班级分组显示班级出现超过2次的数据.
select * from student group by class having count(class)>2;
注意!!!having前后最好字段一致
目的: 为了提高效率和准确性
适用于在创建表的时候进行添加约束条件
意思: 不为空
数据库含义: 必填
例如: 创建一个book表,设置其中的书名(name)字段为不为空
create table book(
id int,
name varchar(20) not null,
author varchar(20));
在已创建好的表中添加 not null约束条件
alter table 表名 modify 字段 类型
例如:alter table student modify age int not null;
在已创建好的表中删除 not null约束条件
alter table 表名 modify 字段 类型
例如:alter table student modify age int null;
意思: 唯一的
数据库含义: 唯一的,不可重复
例如: 创建一个book表,设置其中的id字段为唯一
create table book(
id int unique,
name varchar(20) ,
author varchar(20) );
在已创建好的表中添加unique约束条件
alter table 表名 add unique(字段) ;
在已创建好的表中删除unique约束条件
alter table 表名 drop index 字段;
意思: 默认
数据库含义: 如果表中未填写,系统将会把默认值填入
例如: 创建一个book表,设置其中的作者字段为默认"未知"
create table book(
id int,
name varchar(20) ,
author varchar(20) default "未知");
在已创建好的表中修改default约束
alter table 【表名】alter 【字段】set default ‘xxx’ ;
在已创建好的表中删除default约束
alter table 【表名】alter 【字段】drop default ;
意思: 主码
数据库含义: 唯一标识关系
是not null 和 unique 的总和
create table student(
sid int not null primary key,
gid int not null ,
name varchar(20),
age int,
grade int);
在已创建好的表中修改 primary key约束
alter table 表名 add primary key(字段);
在已创建好的表中删除 primary key约束
alter table 表名 dop primary key;
意思: 外码
数据库含义: 唯一标识关系
create table student(
sid int not null primary key,
gid int not null foreign key references 表名(字段),
name varchar(20),
age int,
grade int);
在已创建好的表中修改 foreign key约束
alter able 表名1 add foreign key(字段) references 表名2(字段名);
在已创建好的表中删除 foreign key约束
alter table 表名 drop foreign key 外键名;
注意!!!查看外键名: show create table 表名 ;
计算()出现的次数
例如:计算student表中,班级2的同学有几个
//eg::计算student表中,班级2的同学有几个
select class, count(class) from student group by class;
求和
例如: 求各班同学的总成绩
//例如: 求各班同学的总成绩
select class,sum(score) as sum from student group by class;
求平均数
例如 : 求各班同学成绩的平均分
//例如 : 求各班同学成绩的平均分
select class,avg(score) as sum from student group by class;
两表或者多表联合查询
//格式1:(两/多表连接',')
select 列名 from 表名1,表名2 where (将表1的字段与表2的相连接)
//格式2:(两表连接join)
select 列名 from 表名1 join 表2 on (字段连接)
//格式3:(多表连接join)
select 列名 from 表名1 join 表2 on (字段连接) join 表3 on 条件
只显示共有部分
公式 : 就是上面的两表连接操作
select 列名 from 表名1 join 表2 on (字段连接)
以左侧表为主,左侧表的内容全部显示,如果右侧没有对应的,补null
格式 : select 列名 from 表名1 left join 表2 on (字段连接)
以右侧表为主,右侧表的内容全部显示,如果左侧没有对应的,补null
格式 : select 列名 from 表名1 right join 表2 on (字段连接)
同一张表
例如:查询同一张表里同时选修了课程1和课程2的学生信息
select * from stu_class as s1,stu_class as s2 where s1.id = s2.id and s1.class = s2.class ;
//格式:
select * from 表1 where id = (select id from 表2 where 条件);
可用于多个表的查询结果合并
注意 : union all 不会自动去重
== union 会自动去重==
//格式:
select * from 表 where 条件 union select * from 表 where 条件;
目的: 提高查找速度
消耗 : 需要额外的空间代价来保存索引数据, 若数据过于庞大,存在危险
show index from 表名;
create index 索引名 on 表名(列名);
若后建索引存在危险,最好是建表时就设计好表的结构
做法 : 加上主键或者unique,这些都是自带索引的约束条件
drop index 索引名 on 表名;
注意 : 所有的删除都存在风险