当前位置: 首页 > news >正文

sql入门基础-2

Dml语句 对数据的增删改查

关键字

Insert增

Update删

Delete改

添加数据

给指定字段添加数据

Insert into 表明 (字段名1,字段名2) values(值1,值2);

给全部字段添加数据--(根据位置对应添加到字段下)

Insert into 表名 values(值1,值2);

添加多条数据--(一次添加两条)

Insert into 表名 values (值1,值2),(值1,值2);

修改数据---不带where则所有的字段更改

                                           唯一值作为条件-id

Update 表名 set 字段名=1 ,字段名=2 .... where 条件

Updae usertable set name=”王五” where id = 1 ;

根据条件删除  ---不携带where则删除表里所有数据

delete from 表名 where 字段=值

DQL--数据库查询语言

关键字 select

 

# 创建表
create table userTable (
    id int comment '唯一值',
    workno varchar(10) comment '工号',
    name varchar(50) comment '姓名',
    gender char(1) comment '性别',
    age tinyint comment '年龄',
    idcard varchar(18) comment '身份证号',
    worknoaddress varchar(50) comment '工作地址',
    entrydate date comment '入职时间'
) comment '员工表';

# 查询当前表 所有字段 字段值类型  默认值等
desc usertable;

# 批量添加           字段                                                    值
insert into userTable(id, workno, name, gender, age, idcard, worknoaddress, entrydate)
values (1,'1','柳岩','女',18,'123123123123123123','武汉','2023-6-26'),
       (2,'2','张无忌','男',20,'123123123123123123','天龙八部','2022-7-26'),
       (3,'3','韦一笑','男',18,'123123123123123123','天龙八部','2021-7-26'),
       (4,'4','周芷若','女',25,null,'天龙八部','2023-7-26'),
       (5,'5','谢逊','男',88,'12312312312312312x','天龙八部','2023-3-26'),
       (6,'6','张三丰','女',100,'123123123123123123','天龙八部','2023-2-26'),
       (7,'7','刘亦菲','女',18,'123123123123123123','武汉','2023-7-26')
       ;




# 查询
select * from usertable;


# ------查询需求------------------------DQl基础查询------

# 基本查询
# --1.查询指定字段-name workon age
select name ,workno,age from userTable;

# 2.查询所有字段返回
select  * from userTable;

# 3.查询所有员工得工作地址,起别名

select worknoaddress as '工作地址' from userTable;

#4查询公司员工得上班地址(不重复)
select distinct worknoaddress from userTable;

# ----------DQL语法条件查询-------------
#  > < >= <= = <>或!=(不等) BETWEEN...AND(在某个范围内含最小,最大)
# IN(...) 在in之后的列表中的值,多选一
# LINK 占位符 模糊匹配( _ 匹配单个字符, % 匹配任意个字符)
# IN NULL 是null
# AND或&& 并且
# OR或|| 或
# NOT 或 !
# 语法 SELECT 字段 from where 条件列表

# 1查询年龄=88的员工
select * from userTable where age = 88;

# 2查询年龄小于20
select * from userTable where age < 20;

# 3查询年龄小于等于20
select * from userTable where age <= 20;

# 4查询没有身份证号的
select * from userTable where idcard is null ;

# 5查询有身份证号的
select * from userTable where idcard is not null ;

# 查询名字是两位的
select * from userTable where name like'__';

# 查询身份证号后带x的
select * from userTable where idcard like '%x';

# 查询15-20的人
select * from userTable where age >=15 && age <= 20 ;
select * from userTable where age between 15 and 20 ;


# 与
select * from userTable where gender='女' && age = 18;
# 或
select * from userTable where age >= 900 || gender = '男';
# 非
select * from userTable where gender != '男';

# -------------DQL聚合函数---将列数据做为整体,进行纵向计算----------------
# count 统计数量
# max 最大
# min 最小
# sum 求和
# avg 平均值

# 语法
# select 聚合函数(字段)from 表名

# ** --null 值不参与聚合函数计算

# 统计员工数量
select count(*)from userTable;

# 统计员工平均年龄
select avg(age)from userTable;

# 统计最大年龄
select max(age) from userTable;

# 统计最小年龄
select min(age)from userTable;

# 统计天龙八部地区所有员工年龄之和
select sum(age) from userTable where worknoaddress = '武汉';


# ------分组查询-----------------
# 语法 select 字段列表 from 表名 [where 条件] GROUP BY 分组字段名 [having 分组后过滤条件]

# **--- where 是对分组前进行过滤   ,having 是分组后进行过滤
# **--- where不能对聚合函数进行判断,而having可以

# 分组查询
# 根据性别分组,统计男性员工  和 女性员工的数量
select count(*) from userTable group by gender;

select gender, count(*) from userTable group by gender;

# 根据性别分组,统计男性  和 女性员工的平均年龄
select avg(age) from userTable group by gender;
select gender , avg(age) from userTable group by gender;

# 查询年龄小于45员工,并根据工作地址分组,获取员工数量大于等于3的工作地址

# --where 过滤聚合函数之前数据    得到<45数据   分组 统计地址数据    对分组数据过滤 >=3的
select worknoaddress , count(worknoaddress) from userTable where age < 45 group by worknoaddress having count(worknoaddress) >= 3 ;

# --年龄小于45  地址  分组  统计
select worknoaddress , count(worknoaddress) from userTable where age < 45 group by worknoaddress ;

# ---********总结重点 执行优先级  where > 聚合函数  > having
# ***---分组之后,查询的字段一般为聚合函数和分组字段查询,查询其他字段无任何和意义

相关文章:

sql入门基础-2

Dml语句 对数据的增删改查 关键字 Insert增 Update删 Delete改 添加数据 给指定字段添加数据 Insert into 表明 (字段名1&#xff0c;字段名2) values&#xff08;值1&#xff0c;值2&#xff09;; 给全部字段添加数据--(根据位置对应添加到字段下) Insert into 表名 values…...

uni-app:实现表格多选及数据获取

效果&#xff1a; 代码&#xff1a; <template><view><scroll-view scroll-x"true" style"overflow-x: scroll; white-space: nowrap;"><view class"table"><view class"table-tr"><view class&quo…...

【图论】树上差分(点差分)

一.题目 输入样例&#xff1a; 5 10 3 4 1 5 4 2 5 4 5 4 5 4 3 5 4 3 4 3 1 3 3 5 5 4 1 5 3 4 输出样例&#xff1a;9 二 .分析 我们可以先建一棵树 但我们发现&#xff0c;这样会超时。 所以&#xff0c;我们想到树上差分 三.代码 /* 5 10 3 4 1 5 4 2 5 4 5 4 5 4 3 5 …...

【wrk2】轻量级性能测试工具

1、背景 wrk/wrk2是针对http协议的基准测试工具,特点是在单击多核CPU的前提下,通过系统自带的高性能I/O机制【epoll、kqueue等】,以多线程和事件模式,在指定的时间和请求范围下对目标机器产生负载。特点如下: 优势劣势1、安装简单、容易上手 2、基于系统自身的高性能机制…...

华为云低代码平台Astro Canvas 搭建汽车展示大屏——实验指导手册

实验背景 大屏应用Astro Canvas是华为云低代码平台Astro的子服务之一&#xff0c;是以数据可视化为核心&#xff0c;以屏幕轻松编排&#xff0c;多屏适配可视为基础&#xff0c;用户可通过图形化界面轻松搭建专业水准的数据可视化大屏。例如汽车展示大屏、监控大屏、项目开发大…...

Nodejs 第七章(发布npm包)

发布npm的包的好处是什么 方便团队或者跨团队共享代码&#xff0c;使用npm包就可以方便的管理&#xff0c;并且还可以进行版本控制做开源造轮子必备技术&#xff0c;否则你做完的轮子如何让别人使用难道是U盘拷贝&#xff1f;面试题我面字节的时候就问到了这个增加个人IP 让更…...

Spring?Boot项目如何优雅实现Excel导入与导出功能

目录 背景EasyExcel 问题分析与解决Spring Boot Excel 导入与导出 依赖引入Excel 导入 基本导入功能进阶导入功能Excel 导出 Excel 导入参数校验 开启校验 校验规则定义 Bean Validation 定义校验规则ExcelValidator 接口定义校验规则校验结果接收 异常捕获接收校验结果contro…...

lable 某个名称换行 \n /n /br axisLabel换行 文字换行 echarts

axisLabel: {interval: 0,textStyle: {color: #D9D9D9,fontSize: fontChart(0.2),lineHeight:12,},formatter: function (params) {// 交通运输、仓储和邮政业, 制造业, 科学研究和技术服务业if (params 交通运输、仓储和邮政业) { return 交通运输、\n仓储和邮政业 }else if …...

025 - max()函数

MAX() 函数: MAX 函数返回一列中的最大值。NULL 值不包括在计算中。 SQL MAX() 语法: SELECT MAX(column_name) FROM table_name; 注释&#xff1a;MAX 也可用于文本列&#xff0c;以获得按字母顺序排列的最高或最低值。 -- 实际操作&#xff08;查询salary的最大值&#x…...

JDK 8.x 微服务启动JVM参数调优实战

微服务启动JVM参数调优实战 1.1 配置JVM启动参数1.2 解释1.3 JVM参数优化思路1.3.1 调整堆内存大小1.3.2 年轻代大小1.3.3 Metaspace 大小1.3.4 栈大小1.3.5 垃圾回收器选择1.3.6 垃圾回收参数1.3.7 预分配内存 1.3.8 禁用 ResizePLAB2. 常用JVM参数 1.1 配置JVM启动参数 服务…...

Web与HTTP

目录 DNS与域名 DNS解析的方式 过程 注册域名 html 名词解释 html的语法 web web2.0 静态页面特点 动态页面 动态页面特点 http协议 工作流程 http的请求方式 get post 状态码 常用状态码 通信套接字 套接字调用的端口 DNS与域名 网络是基于tcp/ip协议进…...

算法刷题Day 56两个字符串的删除操作+编辑距离

Day 56 动态规划 583. 两个字符串的删除操作 class Solution { public:int minDistance(string word1, string word2) {int m word1.size(), n word2.size();vector<vector<int>> dp(m 1, vector<int>(n 1, 0));for (int i 0; i < m; i){dp[i][0] …...

Flutter中Dart语言常用知识

目录 1. 变量和数据类型2. 函数3. 类4. 异常处理5. 泛型6. 变量声明和类型推断&#xff1a;7. 函数定义&#xff1a;8. 类定义和实例化&#xff1a;9. 接口定义&#xff1a;10. 抽象类定义&#xff1a;11. 混合类型列表&#xff1a;12. Flutter 中的 UI 组件&#xff1a;13.Dar…...

11万多英藏对照词典英藏翻译ACCESS\EXCEL数据库

今天继续发一个藏文藏语相关的翻译数据库&#xff0c;即英藏对照词典&#xff0c;加上《5万6千多藏文词典解释ACCESS数据库》以及昨天发的《近13万汉藏对照词典汉藏翻译ACCESS\EXCEL数据库》藏文类的数据就算较全了。 截图下方有显示“共有记录数”&#xff0c;截图包含了表的所…...

浅谈C语言分支循环语句

为什么需要循环控制&#xff1f; 因为在日常生活中或者在程序所处理的问题中常常遇见需要重复处理的问题&#xff0c;用循环语句可以提高代码的运行效率&#xff0c;更快的解决日常生活中遇到的问题。 循环嵌套 就是传说中的套娃&#xff0c;不同的循环语句都可以互相嵌套。 …...

Spring Boot Starter 剖析与实践 | 京东云技术团队

引言 对于 Java 开发人员来说&#xff0c;Spring 框架几乎是必不可少的。它是一个广泛用于开发企业应用程序的开源轻量级框架。近几年&#xff0c;Spring Boot 在传统 Spring 框架的基础上应运而生&#xff0c;不仅提供了 Spring 的全部功能&#xff0c;还使开发人员更加便捷地…...

技术能力提升-《系统架构设计师教程》

在最近的月度读书会上&#xff0c;国林哥分享了下对《系统架构设计教程》的一点见解&#xff0c;在技术管理摸爬滚打了多年&#xff0c;觉得这个认证还是有一定价值&#xff0c;希望对有兴趣了解这门认证考试的朋友有所帮助&#xff0c;起到抛砖引玉的作用。 国林哥从以下四个方…...

【LeetCode 热题 100】矩阵 专题(大多原地算法,需要一定思维)

解题思路 在 代码注释中&#xff01; 文章目录 73. 矩阵置零54. 螺旋矩阵48. 旋转图像240. 搜索二维矩阵 II 73. 矩阵置零 class Solution { public:void setZeroes(vector<vector<int>>& matrix) {// 难点&#xff1a;原地算法// 直接复用 matrix 第一行 和 …...

Java 中为什么要把一个数模(10^9+7)

在计算机科学和编程中&#xff0c;经常会遇到需要对结果进行取模操作的情况。模运算是指将一个数除以另一个数&#xff0c;并取得余数的运算。 在 Java 中&#xff0c;常见的一个数取模的值是 (10^97)&#xff0c;即 1000000007。这个特定的数值经常在算法和数学计算中被使用&…...

RPC与REST有什么区别?

原文&#xff1a;RPC与REST有什么区别&#xff1f; 背景 好多开发的同学在工作中&#xff0c;经常分不清RPC和REST的区别&#xff0c;导致经常沟通不在一个层次上。甚至有些同学把这两个当成同一个东西。 RPC与REST的区别&#xff1f; 对比名称 rpc rest 备注 架构风格 RP…...

短信验证码5大常见漏洞与防御实战

1. 这不是“绕过”&#xff0c;而是对验证码机制的深度体检你有没有遇到过这样的场景&#xff1a;在测试一个新上线的注册流程时&#xff0c;输入手机号、点击“获取验证码”&#xff0c;页面立刻弹出“验证码已发送成功”&#xff0c;但手机却迟迟没收到短信&#xff1b;再点一…...

【Midjourney拍立得风格终极指南】:3步零代码复刻宝丽来胶片质感,92%用户首次尝试即出片

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;拍立得风格的视觉基因解码 拍立得影像的独特魅力&#xff0c;源于其不可复制的物理化学反应与即时成像机制——泛黄边框、柔和渐晕、微妙色偏与颗粒噪点共同构成了一套高度识别性的视觉语法。这种“不…...

Seraphine终极指南:英雄联盟免费智能助手,5分钟提升排位胜率15%

Seraphine终极指南&#xff1a;英雄联盟免费智能助手&#xff0c;5分钟提升排位胜率15% 【免费下载链接】Seraphine 英雄联盟战绩查询工具 项目地址: https://gitcode.com/gh_mirrors/se/Seraphine 还在为英雄联盟排位赛中的战绩查询和BP决策烦恼吗&#xff1f;Seraphin…...

在RK3568开发板上搭建NFS服务器:打通ARM与X86文件共享

1. 项目概述&#xff1a;为什么要在RK3568上折腾NFS&#xff1f;手头有一块瑞芯微RK3568的开发板&#xff0c;性能不错&#xff0c;四核A55的架构&#xff0c;跑个轻量级服务器绰绰有余。最近在做一个边缘计算相关的原型验证&#xff0c;需要在开发板和我的主力工作站之间频繁地…...

2026年度AI接入方案复盘:六大主流API中转/API聚合平台深度测评与选型建议

2026年度AI接入方案复盘&#xff1a;六大主流API中转平台深度测评与选型建议 站在2026年的技术节点回望&#xff0c;企业在构建大模型应用时&#xff0c;早已告别了单纯追求低价的阶段。经过一整年的行业沉淀&#xff0c;我们发现真正影响生产效率的并非单一Token的成本&#…...

《从 0 实现 SGLang》第 1 篇 · LLM 推理引擎到底在做什么

千行代码&#xff0c;一步步搭出一个现代 LLM 推理引擎&#xff0c;吃透大模型推理的每一项关键技术。 本阶段目标 — 最简推理实现 用最朴素的方式把端到端推理跑通&#xff1a;先搭起整体框架&#xff0c;再逐个模块替换为完整实现。整个阶段共 5 篇短文&#xff1a; 序号…...

CANN/asc-devkit MakeNDLayout函数

MakeNDLayout 【免费下载链接】asc-devkit 本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言&#xff0c;原生支持C和C标准规范&#xff0c;主要由类库和语言扩展层构成&#xff0c;提供多层级API&#xff0c;满足多维场景算子开发诉求。 项目地址: https://gitcode.c…...

mPDF实战指南:PHP环境下HTML转PDF的高性能解决方案深度解析

mPDF实战指南&#xff1a;PHP环境下HTML转PDF的高性能解决方案深度解析 【免费下载链接】mpdf PHP library generating PDF files from UTF-8 encoded HTML 项目地址: https://gitcode.com/gh_mirrors/mp/mpdf 在当今数字化办公环境中&#xff0c;PDF文档生成已成为企业…...

分布式团队的代码协作规范:从分支策略到提交信息格式

在分布式团队模式下&#xff0c;代码协作的地域分散、时区差异和沟通成本&#xff0c;给版本控制和质量保障带来了严峻挑战。作为软件测试从业者&#xff0c;我们不仅是代码质量的“守门员”&#xff0c;更需要深入理解并推动执行规范的代码协作流程&#xff0c;从分支管理到提…...

工具调用优化:减少API延迟对Agent性能的影响

《工具调用优化全指南:彻底解决API延迟拖累大模型Agent性能的痛点》 副标题:从原理到落地,覆盖缓存、并行、调度、轻量化改造全链路可复现方案 第一部分:引言与基础 1.1 摘要/引言 你有没有遇到过这种场景:辛辛苦苦开发的智能Agent功能非常强大,能查订单、搜资料、算数…...