MySQL数据库的增删改查和事务操作

提示:各位一定要多动手操作!!

文章目录:

        前言

一、数据定义语言:DDL(操作数据库,表,列等)

二、数据操纵语言:DML(对标中的数据进行增删改)

三、数据查询语言:DQL(根据各种条件查询)

四、约束:

总结


前言

        数据库的增删改查对JavaWeb的学习来说是重要的基础内容,我们必须熟练掌握每一个词的用法,记熟,多用,只有多敲代码才能烂熟于心!


一、数据定义语言:DDL(操作数据库,表,列等)

  1. 显示数据库内容:show databases;

  2.  建立数据库:create database db1;(此处db1表示新创建的数据库名称),创建时可能出现数据库存在的问题,可写成(create database if not exist db1;),这样写会让程序自行判断数据库是否存在,如果不存在才会进行创建数据库,如果存在则不进行数据库的创建。

  3. 删除已有数据库:drop database db1;(此处db1表示已创建的数据库名称),如果db1存在,存在才删除,则可像上述一样改写(drop database if exist db1;)。

  4. 查询当前使用的数据库:select database();

  5. 使用数据库:use db1;(此处db1表示需要使用的数据库名称),输入此条代码后即可进入数据库进行数据库内部表操作。

  6. 查询表名称:show tables;  -----  查询表结构:desc 表名称;
  7. 创建表:切记最后一行末尾不加逗号,括号后面要加逗号。

    MySQL数据库的增删改查和事务操作_第1张图片

  8. 创建表时的数据类型:例如:double(总长度,小数点后面保留的数)。varchar可变长字符串,会根据输入字符串大小对其规定进行变化,有利于节省空间。MySQL数据库的增删改查和事务操作_第2张图片
  9. 删除表:drop table 表名;(drop table if exists 表名)可判断是否存在相同的表,存在才删除;
  10. 修改表:(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;)

二、数据操纵语言:DML(对标中的数据进行增删改)

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='张三';

三、数据查询语言:DQL(根据各种条件查询)

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 '%帅%'(此例查询的是名字里包含帅这个字的人名)

MySQL数据库的增删改查和事务操作_第3张图片

 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不参与计算)

MySQL数据库的增删改查和事务操作_第4张图片

例如: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;(每页显示三条数据,查询第一页数据)

四、约束:

MySQL数据库的增删改查和事务操作_第5张图片

(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;


总结

        此次数据库增删改查的学习,是基础中的重中之重,一定要多加练习,熟悉每一步操作,不能忘记每个关键字,代码敲烂,月薪过万!!!

你可能感兴趣的:(大数据,java-ee)