提示:各位一定要多动手操作!!
前言
一、数据定义语言:DDL(操作数据库,表,列等)
二、数据操纵语言:DML(对标中的数据进行增删改)
三、数据查询语言:DQL(根据各种条件查询)
四、约束:
总结
前言
数据库的增删改查对JavaWeb的学习来说是重要的基础内容,我们必须熟练掌握每一个词的用法,记熟,多用,只有多敲代码才能烂熟于心!
显示数据库内容:show databases;
建立数据库:create database db1;(此处db1表示新创建的数据库名称),创建时可能出现数据库存在的问题,可写成(create database if not exist db1;),这样写会让程序自行判断数据库是否存在,如果不存在才会进行创建数据库,如果存在则不进行数据库的创建。
删除已有数据库:drop database db1;(此处db1表示已创建的数据库名称),如果db1存在,存在才删除,则可像上述一样改写(drop database if exist db1;)。
查询当前使用的数据库:select database();
使用数据库:use db1;(此处db1表示需要使用的数据库名称),输入此条代码后即可进入数据库进行数据库内部表操作。
- 查询表名称:show tables; ----- 查询表结构:desc 表名称;
- 创建表:切记最后一行末尾不加逗号,括号后面要加逗号。
- 创建表时的数据类型:例如:double(总长度,小数点后面保留的数)。varchar可变长字符串,会根据输入字符串大小对其规定进行变化,有利于节省空间。
- 删除表:drop table 表名;(drop table if exists 表名)可判断是否存在相同的表,存在才删除;
- 修改表:(1)、修改表名alter table 表名 remame to 新的表名; (例:alter table db1 rename to db2;) (2)、添加一列:alter table 表名 add 列名 数据类型; (例:alter table db1 add id int;) (3)、修改数据类型:alter table 表名 modify 列名 新数据类型; (例:alter table db1 modify id char(10); ) (4)、修改列名和数据类型:alter table 表名 change 列名 新列名 新数据类型;(例:alter table db1 change id name varchar(10) ) (5)、删除列:alter table 表名 drop 列名; (例:alter table db1 drop id;)
1、添加数据:(1)给指定列添加数据:insert into 表名(列名1,列名2) values(值1,值2);
例如:insert into db1(id,name) values(1,'张三');-- 添加1、张三的数据
(2)给全部列添加数据:insert into 表名 values(值1,值2);(不推荐使用)
例如:insert into db1 values(2,'李四');//添加2、李四这个人的数据
(3)批量添加数据:insert into 表名(列名1,列名2) values(值1,值2),(值1,值2);
2、修改数据:update 表名 set 列名1=值1,列名2=值2 where (此处写条件);
例如:update db1 set name='王五' where id=1;(将第一个id的人名改为王五)
注意:如果update语句没有where条件,将会将表中所有数据修改
3、删除数据:delete from 表名 where 条件;
例如:delete from db1 where name='张三';
1、基础查询:(1)select 字段列名 from 表名; 例如:select name from db1;(查询db1中的name) 例如:select * from db1;(查询db1中的所有内容)
(2)在字段列名前面加distinct关键字可以去除重复内容。例如:select distinct name from db1;
(3)可用as起别名操作。例如:select name, math as 数学,english from db1;
2、条件查询(where):select 字段列表 from 表名 where 条件列表;(注意:NULL不能用=判断,只能用is,is not判断)。or可用in(条件)来代替,形容更加简介。
例如:select * from db1 where age=18;
select * from db1 where age in(18,20,30)(此例表示查询年龄是18,20,30的信息)
select * from db1 where english is not null(此例查询英语成绩不为空)
模糊查询:like ‘条件’,_代表单个任意字符,%代表任意个数字符
例如:select * from db1 where name like '_帅%'(此例查询的是第二个字是帅的人名)
select * from db1 where name like '%帅%'(此例查询的是名字里包含帅这个字的人名)
3、排序查询(order by):select 字段列表 from 表名 order by 排序字段1 排序方式1,排序字段2 排序方式2;
排序方式:asc 升序排序(默认值) ,desc 降序排序。(如果有多个条件,只有前面的条件一样是才会对后面的条件进行排序)。
例如:select * from db1 order by age asc;(对年龄进行升序排序)
select * from db1 order by age desc,english asc;(对年龄降序排序,年龄相同才会升序排序英语成绩)
4、分组查询(group by):
(1)聚合函数:select 聚合函数(列名) from 表名;(聚合函数的计算中null不参与计算)
例如:select count(*) from db1;(可用最快速统计db1中的人数)
(2)select 字段列表 from 表名 where 条件 group by 分组字段名 having 分组条件后筛选
where 和having区别:where是分组前进行限定,不满住条件则不进行分组,having是分组后对分组后条件进行限定;where不能对聚合函数判断,having可用。
执行顺序:where>聚合函数>having
例如:select sex,avg(math) from db1 group by sex;(输出的是分组的男女同学各自的平均分)
select sex,avg(math),count(*) from db1 where math>70 group by sex;(输出的是男女同学的数学平均分和人数,条件是数学成绩大于70)
select sex,avg(math),count(*) from db1 where math>70 group by sex having count(*)>2(相比上面那个例子限制了分组后要人数大于2才进行输出);
5、分页查询(limit):select 字段列名 from 表名 limit 起始索引,查询条目数;(起始索引0开始)
计算公式:起始索引=(当前页码-1)*每页显示条数
例如:select * from db1 limit 0,3;(每页显示三条数据,查询第一页数据)
(1) 例子:create table db1(
id int primary key(主键非空且唯一) auto_increment(自增长), -- 员工编号(主键自增长)
ename varchar(50) not null(非空) unique(唯一), -- 员工姓名,非空且唯一
joinday date not null, -- 入职日期,非空
salary double(7,2) not null, -- 工资,非空
bonus double(7,2) default 0 -- 奖金,如果没有则默认为0
);
可通过:insert into db1(id,ename,joinday,salary,bonus) values(1,'张三','1991-1-1',8800,5500);这个输入进行上面的约束测试。
(2)可以在建完表后进行约束的添加(较为麻烦,一般不使用):
添加约束:alter table 表名 modify 字段名 数据类型 not null;
删除约束:alter table 表名 modify 字段名 数据类型;
(3)外键约束(建表时添加):constraint 外键名称 foreign key(外键列名) references 主表(主表列名)
建完表后添加:alter table 表名 add constraint 外键名称 foreign key(外键字段名称) references 主表(主表列名称);
删除外键约束:alter table 表名 drop foreign key 外键名称;
例子:create table db1(
constraint fk_emp_dept(自己取的外键名称) foreign key(dep_id)(子表的字段列名) references dept(id)(主表的字段列名) (此例根据员工id和部门id相关联)
);
!必须先创建主表才能创建子表,否则会报外键约束错误!
例子:alter table db1 add constrain fk_emp_dept foreign key(dep_id) references dept(id);(在建完表后建立外键约束)
alter table db1 drop foreign key fk_emp_dept;(在建完表后删除外键约束)
1、内连接:
内连接相当于查询两表相交部分;
隐式内连接:select 字段列表 from 表1,表2 where 条件;
例子:select * from db1,db2 where db1.id=db2.id;(此例查询db1中的id和db2中id相同的全部字段列表)
显示内连接:select 字段列表 from 表1 inner join 表2 on 条件;
例子:select * from db1 inner join db2 on db1.id=db2.id;(此例通过显示内连接查询db1表id和db2表id相同的字段列表)
2、外连接:
左外连接:select 字段列表 from 表1 left (outer) join 表2 on 条件;(左外连接相当于查询表1所有数据和表1、表2交集部分)
例子:select * from db1 left join db2 on db1.id=db2.id;(查询db1全部信息和db1和db2相交部分信息)
右外连接:select 字段列表 from 表1 right (outer) join 表2 on 条件;(右外连接相当于查询表2所有数据和表1、表2交集部分)
例子:select * from db1 right join db2 on db1.id=db2.id;(查询db2全部信息和db1和db2相交部分信息)
常使用左外连接,可通过交换表1、表2位置实现从左外连接变成右外连接;
3、子查询(嵌套查询):
(1)单行单列:作为条件值,使用=,!=,>,<等条件判断
select 字段列表 from 表 where 字段名 =(子查询);
例子:select * from db2 where id=(select * from db1 where dname='财务部');(此例查询财务部的员工信息和部门信息)
(2)多行单列:作为条件值,使用in等关键字进行条件判断
select 字段列表 from 表 where 字段名 in(子查询);
例子:select * from db2 where id in(select * from db1 where dname='财务部' or dname='市场部');(此例查询财务部和市场部的员工信息和部门信息)
(3)多行多列:作为虚拟表
select 字段列表 from (子查询) where 条件;
例子:select * from (select * from db1 where join_date > '2021-1-1') t1, db2 where db1.id=db2.id;(此例查询入职日期大于2021-1-1的员工信息和部门信息)
开启事务:start transaction;或者begin;(开启事务后单个查询里的任何修改只对此查询有效,其他查询访问此表时查询到的是开启事务之前的状态)
提交事务:commit;(事务提交后,外部查询才能查询到修改后的状态,mysql默认自动提交)
回滚事务:rollback;(将修改后的数据回滚到开启事务前,避免错误情况)
李四:1000,张三:1000
例子:begin;(开启事务)
update account set money=money-500 where name='李四';(李四金额-500)
update account set money=money+500 where name='张三';(张三金额+500)
commit;(提交事务)
rollback;(回滚事务)
事务四大特征:
- 原子性(Atomicity):事务是不可分割的最小操作单位,要么同时成功,要么同时失败;
- 一致性(Consistency):事务完成时,必须使所有的数据都保持一致状态;
- 隔离性(Isolation):多个事务之间,操作的可见性;
- 持久性(Durability):事务一旦提交或回滚,它对数据库中的数的改变就是永久的;
查询数据库的默认提交方式:select @@autocommit;(显示1为自动提交,0为手动提交)
修改事务的提交方式为手动:set @@autocommit=0;
此次数据库增删改查的学习,是基础中的重中之重,一定要多加练习,熟悉每一步操作,不能忘记每个关键字,代码敲烂,月薪过万!!!