数据库操作

黑马程序员JavaWeb开发教程

文章目录

一、数据库操作-DML

1、添加数据(insert)

  1. 指定字段添加数据:insert into 表名(字段名1,字段名2)values(值1,值2);
  2. 全部字段添加数据:insert into 表名 values(值1,值2);
  3. 批量添加数据(指定字段):insert into 表名(字段名1,字段名2)values(值1,值2),(值1,值2),(值1,值2);
  4. 批量添加数据(全部字段):insert into 表名 values(值1,值2),(值1,值2),(值1,值2);
  5. 注意事项
    • 插入数据时,指定的字段顺序需要与值的顺序是一一对应的
    • 字符串和日期性数据应该包含在引号中
    • 插入的数据大小,应该在字段的规定范围内

2、修改数据(update)

  1. 修改数据:update 表名 set 字段名1=值1,字段名2=值2...[where 条件];
  2. 注意:如果没有知道个条件的话,就是修改的整张表的数据

3、删除数据(delete)

  1. 删除数据:delete from 表名 [where 条件];
  2. 注意事项:
    • Delete 语句的条件也可以有,也可以没有,如果没有条件,则会删除整张表的所有数据
    • Delete语句不能删除某一个字段的值(如果要操作,可以使用update,将该字段的值职位null)

二、 数据库操作-DQL

  • 基本语法

1、基本查询

(1)语法

  1. 查询多个字段:select 字段1,字段2,字段3, from 表名;
  2. 查询所有字段:select * from 表名; * 代表查询所有字段,在实际开发中尽量少用(不直观、影响效率)
  3. 设置别名:select 字段1 [as 别名1],字段2 [as 别名2] from 表名;
  4. 去除重复记录:select distinct 字段列表 from 表名;

2、条件查询(where)

(1)语法

select 字段列表 from 表名 where 条件列表;

(2)构建条件的运算符


-- 员工管理(带约束)
create table tb_emp (
                        id int unsigned primary key auto_increment comment 'ID',
                        username varchar(20) not null unique comment '用户名',
                        password varchar(32) default '123456' comment '密码',
                        name varchar(10) not null comment '姓名',
                        gender tinyint unsigned not null comment '性别, 说明: 1 男, 2 女',
                        image varchar(300) comment '图像',
                        job tinyint unsigned comment '职位, 说明: 1 班主任,2 讲师, 3 学工主管, 4 教研主管',
                        entrydate date comment '入职时间',
                        create_time datetime not null comment '创建时间',
                        update_time datetime not null comment '修改时间'
) comment '员工表';

-- 准备测试数据
INSERT INTO tb_emp (id, username, password, name, gender, image, job, entrydate, create_time, update_time) VALUES
                                                                                                               (1, 'jinyong', '123456', '金庸', 1, '1.jpg', 4, '2000-01-01', '2022-10-27 16:35:33', '2022-10-27 16:35:35'),
                                                                                                               (2, 'zhangwuji', '123456', '张无忌', 1, '2.jpg', 2, '2015-01-01', '2022-10-27 16:35:33', '2022-10-27 16:35:37'),
                                                                                                               (3, 'yangxiao', '123456', '杨逍', 1, '3.jpg', 2, '2008-05-01', '2022-10-27 16:35:33', '2022-10-27 16:35:39'),
                                                                                                               (4, 'weiyixiao', '123456', '韦一笑', 1, '4.jpg', 2, '2007-01-01', '2022-10-27 16:35:33', '2022-10-27 16:35:41'),
                                                                                                               (5, 'changyuchun', '123456', '常遇春', 1, '5.jpg', 2, '2012-12-05', '2022-10-27 16:35:33', '2022-10-27 16:35:43'),
                                                                                                               (6, 'xiaozhao', '123456', '小昭', 2, '6.jpg', 3, '2013-09-05', '2022-10-27 16:35:33', '2022-10-27 16:35:45'),
                                                                                                               (7, 'jixiaofu', '123456', '纪晓芙', 2, '7.jpg', 1, '2005-08-01', '2022-10-27 16:35:33', '2022-10-27 16:35:47'),
                                                                                                               (8, 'zhouzhiruo', '123456', '周芷若', 2, '8.jpg', 1, '2014-11-09', '2022-10-27 16:35:33', '2022-10-27 16:35:49'),
                                                                                                               (9, 'dingminjun', '123456', '丁敏君', 2, '9.jpg', 1, '2011-03-11', '2022-10-27 16:35:33', '2022-10-27 16:35:51'),
                                                                                                               (10, 'zhaomin', '123456', '赵敏', 2, '10.jpg', 1, '2013-09-05', '2022-10-27 16:35:33', '2022-10-27 16:35:53'),
                                                                                                               (11, 'luzhangke', '123456', '鹿杖客', 1, '11.jpg', 2, '2007-02-01', '2022-10-27 16:35:33', '2022-10-27 16:35:55'),
                                                                                                               (12, 'hebiweng', '123456', '鹤笔翁', 1, '12.jpg', 2, '2008-08-18', '2022-10-27 16:35:33', '2022-10-27 16:35:57'),
                                                                                                               (13, 'fangdongbai', '123456', '方东白', 1, '13.jpg', 1, '2012-11-01', '2022-10-27 16:35:33', '2022-10-27 16:35:59'),
                                                                                                               (14, 'zhangsanfeng', '123456', '张三丰', 1, '14.jpg', 2, '2002-08-01', '2022-10-27 16:35:33', '2022-10-27 16:36:01'),
                                                                                                               (15, 'yulianzhou', '123456', '俞莲舟', 1, '15.jpg', 2, '2011-05-01', '2022-10-27 16:35:33', '2022-10-27 16:36:03'),
                                                                                                               (16, 'songyuanqiao', '123456', '宋远桥', 1, '16.jpg', 2, '2010-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:05'),
                                                                                                               (17, 'chenyouliang', '12345678', '陈友谅', 1, '17.jpg', null, '2015-03-21', '2022-10-27 16:35:33', '2022-10-27 16:36:07'),
                                                                                                               (18, 'zhang1', '123456', '张一', 1, '2.jpg', 2, '2015-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:09'),
                                                                                                               (19, 'zhang2', '123456', '张二', 1, '2.jpg', 2, '2012-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:11'),
                                                                                                               (20, 'zhang3', '123456', '张三', 1, '2.jpg', 2, '2018-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:13'),
                                                                                                               (21, 'zhang4', '123456', '张四', 1, '2.jpg', 2, '2015-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:15'),
                                                                                                               (22, 'zhang5', '123456', '张五', 1, '2.jpg', 2, '2016-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:17'),
                                                                                                               (23, 'zhang6', '123456', '张六', 1, '2.jpg', 2, '2012-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:19'),
                                                                                                               (24, 'zhang7', '123456', '张七', 1, '2.jpg', 2, '2006-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:21'),
                                                                                                               (25, 'zhang8', '123456', '张八', 1, '2.jpg', 2, '2002-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:23'),
                                                                                                               (26, 'zhang9', '123456', '张九', 1, '2.jpg', 2, '2011-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:25'),
                                                                                                               (27, 'zhang10', '123456', '张十', 1, '2.jpg', 2, '2004-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:27'),
                                                                                                               (28, 'zhang11', '123456', '张十一', 1, '2.jpg', 2, '2007-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:29'),
                                                                                                               (29, 'zhang12', '123456', '张十二', 1, '2.jpg', 2, '2020-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:31');


select * from tb_emp;

# 条件查询
--  =================== DQL: 条件查询 ======================
-- 1. 查询 姓名 为 杨逍 的员工
select username,name from tb_emp where name='杨逍';


-- 2. 查询 id小于等于5 的员工信息
select * from tb_emp where id<=5;

-- 3. 查询 没有分配职位 的员工信息
select  * from tb_emp where job is null;



-- 4. 查询 有职位 的员工信息
select  * from tb_emp where job is not null;


-- 5. 查询 密码不等于 '123456' 的员工信息
select * from tb_emp where password<>'123456';

-- 6. 查询 入职日期 在 '2000-01-01' (包含) 到 '2010-01-01'(包含) 之间的员工信息
select * from tb_emp where entrydate between '2000-01-01' and '2010-01-01';


-- 7. 查询 入职时间 在 '2000-01-01' (包含) 到 '2010-01-01'(包含) 之间 且 性别为女 的员工信息
select * from tb_emp where entrydate between '2000-01-01' and '2010-01-01' and gender=2;


-- 8. 查询 职位是 2 (讲师), 3 (学工主管), 4 (教研主管) 的员工信息
select * from tb_emp where job in(2,3,4);


-- 9. 查询 姓名 为两个字的员工信息
    select * from tb_emp where name like '__';


-- 10. 查询 姓 '张' 的员工信息
select * from tb_emp where name like '张%';

3、分组查询(group by)

(1)聚合函数

  1. 介绍:将一列数据作为一个整体,进行纵向计算
  2. 语法:select 聚合函数(字段列表) from 表名
  3. 常用聚合函数
    • count:统计数量
    • max:最大值
    • min:最小值
    • avg:平均值
    • sum:求和
  4. 注意事项
    • null值不参与所有聚合函数运算
    • 统计数量可以使用count(*)count(字段),count(常量),推荐使用count(*)

(2) 分组查询语法

  1. select 字段列表 from 表名[where 条件] group by 分组字段名 [having 分组后过滤条件];

    -- =================== DQL: 分组查询 ======================
    -- 聚合函数

    -- 1. 统计该企业员工数量
    select count(*) from tb_emp;

    -- 2. 统计该企业员工 ID 的平均值
    select avg(id) from tb_emp;

    -- 3. 统计该企业最早入职的员工
    select min(entrydate) from tb_emp;

    -- 4. 统计该企业最迟入职的员工
    select max(entrydate) from tb_emp;

    -- 5. 统计该企业员工的 ID 之和
    select sum(id) from tb_emp;

  2. where与having区别

    • 执行实际不同:where是分组之前进行过滤,不满足where条件,不参与分组;而having是分组之后对结果进行过滤
    • 判断条件不同:where不能对聚合函数进行批判断,而having可以
  3. 注意事项

    • 分组之后,查询的字段一般是聚合函数和分组字段,查询其他的字段没有意义
    • 执行顺序where > 聚合函数 > having

4、排序查询(order by)

(1)语法

  1. select 字段列表 from 表名 [where 条件列表][group by 分组字段] order by 字段1 排序方式1,字段2 排序方式2
  2. 排序方式
    • ASC:升序(默认)
    • DESC:降序
  3. 注意事项:如果是多字段排序,当第一个字段值相同的时候,才会根据第二个字段的值进行排序

5、分页查询(limit)

(1)语法

  1. 分页查询:select 字段列表 from 表名 limit 起始索引,查询记录数;
  2. 注意事项
    • 起始索引从0 开始,起始索引=(查询页码-1)*每页显示记录数
    • 分页查询是数据库的方言,不同的数据库有不同的视线,MySQL中是limit
    • 如果查询的是第一页数据,其实索引可以省略,直接简写 limit 10;

(2)函数

  • if(表达式,true-valuue,false-value):当表达式为true的时候取值true-value,当表达式取值为false的时候,取值false-value
  • case 表达式 when value1 then result1 [ when value2 then result2] [ when value3 then result3] end
相关推荐
时光书签22 分钟前
Mongodb副本集群为什么选择3个节点不选择4个节点
数据库·mongodb·nosql
人才程序员2 小时前
【C++拓展】vs2022使用SQlite3
c语言·开发语言·数据库·c++·qt·ui·sqlite
极客先躯2 小时前
高级java每日一道面试题-2025年01月23日-数据库篇-主键与索引有什么区别 ?
java·数据库·java高级·高级面试题·选择合适的主键·谨慎创建索引·定期评估索引的有效性
指尖下的技术2 小时前
Mysql面试题----MyISAM和InnoDB的区别
数据库·mysql
永远是我的最爱3 小时前
数据库SQLite和SCADA DIAView应用教程
数据库·sqlite
指尖下的技术3 小时前
Mysql面试题----为什么B+树比B树更适合实现数据库索引
数据结构·数据库·b树·mysql
数据馅3 小时前
python自动生成pg数据库表对应的es索引
数据库·python·elasticsearch
峰子20124 小时前
B站评论系统的多级存储架构
开发语言·数据库·分布式·后端·golang·tidb
浏览器爱好者5 小时前
如何使用MongoDB进行数据存储?
数据库·mongodb
yuanpan5 小时前
MongoDB中的横向扩容数据分片
数据库·mongodb