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

Mysql的基本用法(上)非常详细、快速上手

上篇结束了java基础,本篇主要对Mysql中的一些常用的方法进行了总结,主要对查询方法进行了讲解,包括重要的多表查询用到的内连接和外连接等,以下代码可以直接复制到可视化软件中,方便阅读以及练习;


SELECT *FROM employees;
SELECT employee_id,salary*(1+IFNULL(commission_pct,0))*12 "年工资"FROM employees;
#着重号:表名和关键字重合了需要用:
SELECT *FROM `order`;
#查询常数:会自动在前面加一列:
SELECT "hello",123,employee_id FROM employees;
#显示表结构:表的信息:
DESCRIBE employees;
#去重复:distinct:
SELECT job_id FROM employees;
SELECT DISTINCT job_id FROM employees;
#where条件查询:一定要在from结构的后面:
SELECT *FROM employees WHERE last_name='kING';
SELECT *FROM employees WHERE department_id=90;
#运算符:此处判断是否等于不用两个==,一个=即可;
SELECT employee_id FROM employees WHERE employee_id %2=0;
SELECT 1=0,1!=0;
#安全等于<=>,专门为null而使用;以下是例子:首先null参与比较的话结果全是null,无论是1=null还是1>null结果都是null;如果用安全等于,就会结果正常值;
SELECT 1=NULL;
SELECT 1<=>NULL;
SELECT employee_id,salary,commission_pct FROM employees WHERE commission_pct=NULL;
SELECT employee_id,salary,commission_pct FROM employees WHERE commission_pct<=>NULL;
#运算符:isnull is not null isnull()这个是一个方法;
SELECT employee_id,salary,commission_pct FROM employees WHERE commission_pct IS NULL;
SELECT employee_id,salary,commission_pct FROM employees WHERE isnull(commission_pct);
SELECT employee_id,salary,commission_pct FROM employees WHERE commission_pct IS NOT NULL;
#between and:
SELECT employee_id,salary FROM employees WHERE salary BETWEEN 6000 AND 8000;
#in not in:例如查询部门号为10,20,30的员工信息:
SELECT employee_id,salary,department_id FROM employees WHERE department_id=10 OR department_id=20 OR department_id=30;
SELECT employee_id,salary,department_id FROM employees WHERE department_id IN(10,20,30);
#LIKE 模糊查询:
#查询last_name中包含字符串‘a’的员工信息:注意 % 代表前面后面有不确定个字符;例如以a开头:a%;以a结尾:%a;下划线代表一个不确定的字符,例如查询lastname第二个字符是a的员工信息可以用:_a%;
SELECT  employee_id,salary,last_name FROM employees WHERE last_name LIKE '%a%';
#排序order by 默认是从低到高;从高到低是用ASC; 
SELECT employee_id,last_name,salary FROM employees order BY salary DESC;
#此处计算出来了年薪然后起别名annual_salary;
#一定要注意,列的别名只能在order by中使用,不能在where中使用;
SELECT employee_id,last_name,salary,salary*12 annual_salary FROM employees order BY annual_salary DESC;
#二级排序:按照department_id升序排序,此时可能有想同的,那对于相同的按照salary降序排序:一样的三级排序就是在后面在加上一部分
SELECT employee_id,last_name,salary FROM employees order BY employee_id ASC,salary DESC;
#limit实现分页显示:在后面加上即可;例如查询32、33这两条数据:limit后面第一个参数是第几个的前一个,然后第二个参数代表每几个为一页;
SELECT *FROM employees LIMIT 31,2;
#多表查询:分为等值连接和非等值连接;自连接和非自连接;内连接和外连接三种类型;
#例如想查询一个数据,需要先从一个表中找到对应信息,然后根据这个对应信息再去查询另一个表中查询重要信息,
#然后根据这个重要信息再去查找另一个表最终得到数据;因此,这种方法非常麻烦,所以想将表进行连接,多表查询;#以下department_name在departments表中,employee_id在employees表中,然后共同的属性是departent_id,但是
#这样查询是错误的,得到的是笛卡尔积,缺少了多表的连接条件;
SELECT employee_id,department_name FROM employees,departments;
#正确方式:此处多查询一下department_id,这两个表中都有这个属性,查询的时候要指明是哪个表里的;
SELECT employee_id,department_name,employees.department_id
FROM employees,departments 
WHERE employees.department_id=departments.department_id;
#三表连接:查询employee_id,last_name,department_name,city;
SELECT employee_id,last_name,department_name,city
from employees,departments,locations
WHERE employees.department_id=departments.department_id AND locations.location_id=departments.location_id
#非等值连接:上面例子是等值连接,下面是非等值连接:
SELECT last_name,salary,grade_level
FROM employees,job_grades
WHERE salary BETWEEN lowest_sal AND highest_sal;
#自连接和非自连接:
#想查询员工id和姓名,以及其管理者的id和姓名,这两个都在一张表中,要自己和自己连接:这时必须要起别名;
#!!!注意,如果对表起别名后,select和where语句必须要使用别名,不能使用原来的表名;
SELECT emp.employee_id,emp.last_name,manager.employee_id,manager.last_name
FROM employees emp,employees manager
WHERE emp.manager_id=manager.employee_id;
#!!!内连接和外连接:
#内连接:合并具有同一列的两个以上的表的行,结果集中不包含一个表与另一个表不匹配的行;上面那种就是内连接;
#外连接:有的员工可能没有部门,也有的部门建好了,但是还没有员工,此时想把这些数据也查出来;
#上面的多表查询都是都是内连接,并且用的都是SQL92语法的,最好是要用SQL99语法:举例:三表连接:
SELECT employee_id,last_name,department_name,city
FROM employees JOIN departments
ON employees.department_id=departments.department_id
JOIN locations
ON departments.location_id=locations.location_id;
#外连接分为左外连接,右外连接,满外连接;
#左外连接:两个表在连接过程中除了返回满足连接条件的行以外还返回左表中不满足条件的行;右外连接就是返回了右表中不满足条件的行;
#练习:查询所有的员工的employee_id,last_name,department_name;!!!注意是所有的,说明就是要用外连接;
#Mysql不支持SQl92实现外连接,只能用SQL99语法:
#左外连接:也就是练习答案:
SELECT employee_id,department_name
FROM employees LEFT OUTER JOIN departments#此处要用左外连接,可以看到就查询到了除了符合的,也查询到了没有部门的那个员工;
ON employees.department_id=departments.department_id;
#右外连接:
SELECT employee_id,department_name
FROM employees RIGHT OUTER JOIN departments#查询到了没有人员的部门
ON employees.department_id=departments.department_id;
#满外连接:sql不支持ful,因此需要重新实现:
#SELECT employee_id,department_name
#FROM employees FULL JOIN departments
#ON employees.department_id=departments.department_id;
#引入UNION,返回两个查询结果集的并集,去除重复记录(中间交集部分);UNIONALL效率更高,没有去重,也就是中间交集部分加了两遍;

下面按照本图进行外连接查询的练习:

#左中图(左外连接去除交集部分):参考word文档,
SELECT employee_id,department_name
FROM employees LEFT JOIN departments
ON employees.department_id=departments.department_id
WHERE departments.department_id IS NULL;#右边没有就用右表null;
#右中图(右外连接去除交集部分):
SELECT employee_id,department_name
FROM employees RIGHT JOIN departments
ON employees.department_id=departments.department_id
WHERE employees.department_id IS NULL;#左边没有就用左表null;
#左下图:满外连接:左上图(左外连接) UNION ALL 右中图(去除交集的右外连接):
SELECT employee_id,department_name
FROM employees LEFT OUTER JOIN departments
ON employees.department_id=departments.department_id
UNION ALL 
SELECT employee_id,department_name
FROM employees RIGHT JOIN departments
ON employees.department_id=departments.department_id
WHERE employees.department_id IS NULL;
#右下图(右中图UNION ALL左中图)
SELECT employee_id,department_name
FROM employees LEFT JOIN departments
ON employees.department_id=departments.department_id
WHERE departments.department_id IS NULL
UNION ALL
SELECT employee_id,department_name
FROM employees RIGHT JOIN departments
ON employees.department_id=departments.department_id
WHERE employees.department_id IS NULL;

相关文章:

Mysql的基本用法(上)非常详细、快速上手

上篇结束了java基础&#xff0c;本篇主要对Mysql中的一些常用的方法进行了总结&#xff0c;主要对查询方法进行了讲解&#xff0c;包括重要的多表查询用到的内连接和外连接等&#xff0c;以下代码可以直接复制到可视化软件中&#xff0c;方便阅读以及练习&#xff1b; SELECT *…...

使用Vite创建React + TypeScript(node版本为16.17.0,含资源下载)

PC端 安装指令&#xff1a; npm create vitelatest react-ts-pro -- --template react-tsVite是一个框架无关的前端工具链&#xff0c;可以快速的生成一个React TS的开发环境&#xff0c;并且可以提供快速的开发体验说明&#xff1a; 1. npm create vitelatest固定写法&#…...

Springboot集成RabbitMq二

接上一篇&#xff1a;Springboot集成RabbitMq一-CSDN博客 1、搭建项目-消费者 与之前一样 2、创建配置类 package com.wym.rabbitmqconsumer.utils;import org.springframework.amqp.core.Binding; import org.springframework.amqp.core.BindingBuilder; import org.spring…...

机器学习笔记 - 基于Python的不平衡数据的欠采样技术

一、简述 随着从不同的来源生成和捕获大量数据。尽管信息量巨大,但它往往反映了现实世界现象的不平衡分布。数据不平衡的问题不仅仅是统计上的挑战,它对数据驱动模型的准确性和可靠性具有深远的影响。 以金融行业欺诈检测为例。尽管我们希望避免欺诈,因为其具有高度破坏性,…...

facebook广告的基础知识

Facebook广告是在Facebook、Instagram、Audience Network等与Facebook相关的SNS和服务上投放的广告。以下是关于Facebook广告的基础知识&#xff1a; 广告类型&#xff1a; 静态图片广告&#xff1a;主要通过Facebook的新闻提要投放的图片广告&#xff0c;可以张贴产品和服务…...

java常见面试题:什么是异常?Java中的异常有哪些分类?

异常是一个汉语词语&#xff0c;读音为y chng&#xff0c;指非正常的&#xff1b;不同于平常的&#xff1b;非常。在Java中&#xff0c;异常&#xff08;Exception&#xff09;是程序在运行过程中出现的不正常情况&#xff0c;例如除以零、数组越界等。异常分为两大类&#xff…...

类的加载顺序问题-demo展示

面试的的时候经常会被问到包含静态代码块、实例代码块和构造器等代码结构的加载顺序问题&#xff0c;下面借用一个面试题&#xff0c;回顾一下类的代码加载顺序。 public class AooTest {public static void main(String[] args) {AooTest.f1();}static AooTest test1 new Ao…...

[蓝桥杯2020国赛]答疑

答疑 题目描述 有 n 位同学同时找老师答疑。每位同学都预先估计了自己答疑的时间。 老师可以安排答疑的顺序&#xff0c;同学们要依次进入老师办公室答疑。 一位同学答疑的过程如下&#xff1a; 首先进入办公室&#xff0c;编号为 i 的同学需要 si​ 毫秒的时间。然后同学问…...

【AIGC表情prompt】提示词练习技巧

表情类提示词练习技巧 医疗机器人&#xff0c;男人笑脸景深&#xff0c;数据&#xff0c;座标&#xff0c;12k,c4d渲染&#xff0c;高分辨率&#xff0c;,暖色调&#xff0c;高清对比 医疗机器人&#xff0c;男人微笑&#xff0c;景深&#xff0c;数据&#xff0c;座标&#xf…...

SpringBoot项目的三种创建方式

手动创建方式&#xff1a; ①&#xff1a;新建maven项目 ②&#xff1a;引入依赖 <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.3.10.RELEASE</version>&l…...

【docker实战】01 Linux上docker的安装

Docker CE是免费的Docker产品的新名称&#xff0c;Docker CE包含了完整的Docker平台&#xff0c;非常适合开发人员和运维团队构建容器APP。 Ubuntu 14.04/16.04&#xff08;使用 apt-get 进行安装&#xff09; # step 1: 安装必要的一些系统工具 sudo apt-get update sudo ap…...

Baumer工业相机堡盟工业相机如何通过NEOAPI SDK设置相机的图像剪切(ROI)功能(C#)

Baumer工业相机堡盟工业相机如何通过NEOAPI SDK设置相机的图像剪切&#xff08;ROI&#xff09;功能&#xff08;C#&#xff09; Baumer工业相机Baumer工业相机的图像剪切&#xff08;ROI&#xff09;功能的技术背景CameraExplorer如何使用图像剪切&#xff08;ROI&#xff09;…...

软件测试之安全测试

一、测试范围 管理系统&#xff1a;url、登录框、搜索框、输入框、文件上传、文件下载 客户端&#xff1a;搜索框、输入框、文件上传、系统功能 二、测试点 密码安全 XSS注入 SQL注入 操作越权 上传安全 下载安全 三、工具 fiddler sqlmap 同时&#xff0c;在这我为…...

【华为OD机试真题2023CD卷 JAVAJS】会议室占用时间

华为OD2023(C&D卷)机试题库全覆盖,刷题指南点这里 会议室占用时间 时间限制:1s 空间限制:256MB 限定语言:不限 题目描述: 现有若干个会议,所有会议共享一个会议室,用数组表示每个会议的开始时间和结束时间,格式:[[会议1开始时间,会议1结束时间], [会议2开始时间…...

UR5机器人的旋转向量转换到四元数,再从四元数转换到旋转向量python代码

能够通过接口获得UR5机器人末端在基坐标系下的位姿&#xff0c;姿态表示方法是用旋转向量表示的&#xff0c;一般会涉及到四元数和旋转向量之间的转换。 1、方法一 import numpy as np from pytransform3d import rotations as pr import copy # 输入旋转向量 quaternion2 n…...

MD5--加密原理及代码示例(C#)

1.MD5详述 MD5&#xff08;Message-Digest Algorithm 5&#xff09;是一种哈希算法&#xff0c;用于将任意长度的信息映射为固定长度的哈希值&#xff08;128位&#xff09;。MD5算法具有以下特点&#xff1a; 哈希值长度固定&#xff1a;MD5算法将任意长度的输入数据计算为128…...

理解 RPC 与 Protobuf:完整指南

一、Protobuf 数据格式简析 Protobuf 是什么&#xff1f; 在数据密集型应用领域&#xff0c;Google 开发的 Protobuf 作为一种高效数据编码方式而广受欢迎。它胜任于 JSON 及 XML 对比&#xff0c;不仅在体积和速度上表现出色&#xff0c;而且其结构化方式优化了网络传输中的…...

成为一名合格的前端架构师,前端知识技能与项目实战教学

一、教程描述 本套前端架构师教程&#xff0c;大小35.94G&#xff0c;共有672个文件。 二、教程目录 01.node介绍和环境配置&#xff08;共6课时&#xff09; 02.ES6语法&#xff08;共5课时&#xff09; 03.node基础&#xff08;共29课时&#xff09; 04.Express框架&am…...

前端 富文本编辑器原理

富文本编辑器是一种用于编辑和展示富文本内容&#xff08;包括文字、图片、视频等&#xff09;的工具。它通常提供了类似于Microsoft Word的功能&#xff0c;使用户可以对文本进行格式化、插入图片和链接、调整字体样式等操作。在前端开发中&#xff0c;我们可以使用JavaScript…...

Java网络编程之IP,端口号,通信协议(UDP,TCP)

目录 1.软件架构2.网络编程三要素3.IP1.IPV42.IPV6 4.端口号5.协议1.UDP协议1.单播2.组播3.广播 2.TCP协议1.三次握手2.四次挥手 1.软件架构 ①C/S&#xff1a;客户端/服务器 在用户本地需要下载安装客户端程序&#xff0c;在远程有一个服务器端程序。 优点&#xff1a;画面精美…...

iOS和iPadOS设备启动到打开App

一、设备启动过程 启动过程每个步骤包含的组件都经 Apple 加密签名以启用完整性检查&#xff0c;因此只有在验证信任链后&#xff0c;启动才能继续&#xff1b; 这些组件包括引导载入程序、内核、内核扩展项和蜂窝网络基带固件&#xff1b; 这一安全启动链的设计旨在验证软件的…...

【INTEL(ALTERA)】如何使用 Quartus命令行导入 .qud 文件?

说明 英特尔 Quartus Prime 软件用户定义的设备文件 &#xff08;.qud&#xff09; 包含允许在安装 英特尔 Quartus Prime 软件之间传输设备的设备信息。 要导入 .qud 文件中定义的设备&#xff0c;请使用 英特尔 Quartus Prime 软件中的 quartus_cpf 命令行工具&#xff0c;…...

js创建服务器,以及对接口的理解和创建

// 创建服务 const app http.createServer((req, res)>{ // 设置给前端返回信息的字符编码 res.setHeader(content-type, text/html; charsetutf-8) let address req.url.split(?)[0] //首先创建一个数组&#xff0c;后面把它的数据放在JSON文件 let…...

【Bootstrap学习 day7】

Bootstrap按钮 按钮样式 使用.btn相关类实现 <button type"button" class"btn">基本按钮</button> <button type"button" class"btn btn-primary">主要按钮</button> <button type"button" cl…...

Zookeeper无法启动,报“Unable to load database on disk”

转载说明&#xff1a;如果您喜欢这篇文章并打算转载它&#xff0c;请私信作者取得授权。感谢您喜爱本文&#xff0c;请文明转载&#xff0c;谢谢。 问题描述&#xff1a; 测试环境部署zookeeper的服务器磁盘满了&#xff0c;引起服务异常&#xff0c;将zookeeper进程杀掉之后&…...

【Web2D/3D】CSS3的2D/3D转换、过渡、动画(第一篇)

1. 前言 本篇开始介绍Web2D和3D相关基础知识&#xff0c;会从CSS3的2D/3D转换、过渡、动画&#xff0c;讲到Canvas 2D图形绘制&#xff0c;再到SVG&#xff0c;最后到WebGL。 坐标系&#xff1a;左上点是坐标原点(0,0)&#xff0c;x轴正方向向右&#xff0c;y轴正方向向下&…...

uView NumberBox 步进器

该组件一般用于商城购物选择物品数量的场景 注意&#xff1a;该输入框只能输入大于或等于0的整数 #平台差异说明 App&#xff08;vue&#xff09;App&#xff08;nvue&#xff09;H5小程序√√√√ #基本使用 通过v-model绑定value初始值&#xff0c;此值是双向绑定的&…...

三菱plc的点动控制循环(小灯闪烁,单控气缸循环)

以为前一段时间小编做了一个气缸定时循环的程序&#xff0c;根据程序有不足之处&#xff0c;所以小编写下这篇文章&#xff0c;将网络上的plc小灯控制进行总结&#xff01;如果对你有帮助&#xff0c;不要忘了点赞收藏&#xff01;如果有更加好的梯形图&#xff0c;欢迎评论&am…...

学习Go语言Web框架Gee总结--http.Handler(一)

学习Go语言Web框架Gee总结--http.Handler http-base/go.modhttp-base/main.gohttp-base/gee/gee.gohttp-base/gee/go.mod 网站学习来源&#xff1a;Gee 代码目录结构&#xff1a; http-base/go.mod //指定当前模块的名称为 "example" module example//指定当前模…...

react+redux+antd-mobile 之 记账本案例

1.环境搭建 //使用CRA创建项目&#xff0c;并安装必要依赖&#xff0c;包括下列基础包 //1. Redux状态管理 - reduxjs/toolkit 、 react-redux //2. 路由 - react-router-dom //3. 时间处理 - dayjs //4. class类名处理 - classnames //5. 移动端组件库 - antd-mobile //6. 请…...

wordpress baidu插件/做企业网站建设的公司

作者&#xff1a;闻币知天下 BitPay是世界上最受欢迎的比特币支付处理公司之一&#xff0c;因难以忍受BCE高额的交易成本&#xff0c;去年年底&#xff0c;BitPay在自己的支付平台和借记卡中添加比特币现金&#xff08;BCH&#xff09;支持&#xff0c;这标志着该平台支持更多加…...

建设网站的重要意义/深圳优化服务

声明&#xff1a; 按类别特征词选择算法声明 vector<pair<string,double>>LocalDFFeatureSelectionForPerclass(DICTIONARY&mymap,CONTINGENCY&contingencyTable,stringclassLabel);//局部DF法针对每个词对每个类别进行排序voidDFFeatureSelection(vector&…...

杭州建设职业技术学院招聘信息网站/代运营是什么意思

JVM 中对象咋创建啊&#xff0c;又怎么访问啊 虚拟机遇到 new 指令&#xff0c;会根据指令参数去常量池找对应类的符号引用&#xff0c;如果没找到会进行类加载&#xff0c;此时会执行类构造器指令。类加载完成之后&#xff0c;初始化之前&#xff0c;开始进行对象内存分配&…...

企业建站公司案例/人工智能培训课程

一、 直接插入排序思想&#xff1a; 将待排序的记录Ri&#xff0c;插入到已排好序的记录表R1, R2 ,…., Ri-1中&#xff0c;得到一个新的、记录数增加1的有序表。 直到所有的记录都插入完为止。 设待排序的记录顺序存放在数组R[1…n]中&#xff0c;在排序的某一时刻&#xff…...

wordpress全站pjax/百度公司招聘信息

持续更新中。。。 尝试用蓝牙hid协议 文章目录1.个人实践1.1 app在后台处于没有被系统杀死时&#xff0c;可以自动重连和发数据1.2 但在后台被系统杀死(没有被收到杀死)&#xff0c;当连接状态发生变化的时候&#xff0c;系统会唤醒app,扫描后会调用1.3 因为后台获取位置时&…...

电子商务网站建设收获/湖南网站建设工作室

原文网址&#xff1a;http://blog.sina.com.cn/s/blog_5bdee3020101pvgy.html 市面上&#xff0c;经常充斥着&#xff0c;大量双卡双待手机&#xff0c;而许多消费者只是知道这种手机可以插入两个卡&#xff0c;直接打电话&#xff0c;而你真正的理解其中的含义吗&#xff1f; …...