[mysql]最基本的SELECT...FROM结构

news2025/1/6 19:43:13

第0种:最基本的查询语句

SELECT 字段名,字段名 FROM 表名

SELECT 1;

SELECT 1+1,3*2;

FROM

SELECT 1+1,3*2 FROM DUAL;#dual:伪表 我们可以用它来保持一个平衡

这里我们的值不需要在任何一个表里,所以我们可以用dual来表示表

这里的*号代表的就是所有内容.这里的字段前面是id,后面是名,后面的是姓.邮箱,号码,雇佣时间,部门id,工资,奖金比例,管理者id,部门id

比如我们想查询一下员工的id

SELECT employee_id,last_name,salary FROM employees;

就会出现下面的结果

字段的最后一个记得不要加逗号.加了就会出错,字段之间要加逗号,不加就变成字段别名了

列的别名:

别名是怎么回事呢,其实就是一个外号.给他起另一个名字,

大家尽量熟悉熟悉这个 表的内容 ,我们之后都会用这个表

SELECT employee_id,last_name,department_id FROM emplyees;

我们用navicat运行代码之后,就会出现一个表在下面,这个被叫做结果集,结果集的名字就是我们表里的名字,能不能不一致呢,是可以的,我们可以在字段名的后面加一个空格,在写我们希望他叫的名字.比如 我们想给emplyee_id叫emp_id就可以这样写

SELECT emplyees_id emp_id,last_name,department_id FROM employees;

这里就会发现我们结果集的名字变成了emp_id,也就是我们起的别名

我们还能写上AS,它是ALIAS的缩写翻译也就是别名,是可以省略的,如图.

别名可以使用一对""引起来

大家可能会奇怪为什么要加一个"",这不是很鸡肋吗,其实在有一些场景下就不能不去了

比如我们这个代码SELECT employee_id,last_name,salary*2 annual sala FROM employees;我们希望他叫annual sala

大家可能看到这个报错,就害怕,其实不用,因为如果不报错信息,让你自己的去找,短句还好,长一点不得要你的命.就像医生,明明有精确的仪器,你硬要望闻问切,那是不是就不合适了.

SELECT employee_id,last_name,salary*2 "annual sala" FROM employees;

这样是不是就不报错了

可能大家会疑惑单引号可不可以,我们也试一试

也可以,注意我们强调我们是要用""引起来,不要用'',因为mysql的自语言不太标准,如果安装SQL标准ANSI里的要求就是"",大家开发的时候不要用'',太不专业了会被人笑话.单引号在字符串和日期的变量的时候使用也是可以的..

这里还是那个问题,字符串在sql语言的ANSI规范里要求用单引号,但是mysql不是太严谨,如果我们用的是oracle这里就会报错.我们还是要严谨一点.养成好习惯

去重重复行

我们要看看一共有多少个部门在我们的表里,这个述求是不是合情合理啊.

错误的:SELECT department_id FROM employees;

比如现在领导让我们列一下我们一共有哪些部门,如果我们打印这个是不是就不太合适,如果有1000个员工就要打印1000条出来,我们是不是要去掉重复值阿.

我们就在前面加一个关键词DISTINCT

正确的:SELECT DISTINCT department_id FROM employees;

错误的:SELECT salary,DISTINCT department_id FROM employees;

大家觉得这么写是正确的吗,

当然是错误的,如果没有DISTINCT的话肯定是没问题的,但是因为我们有了DISTINCT,肯定是不能执行的,因为salary有107条,但是你把部门去重了可能只有12个部门,那一个字段107条一个字段12条,这样肯定不行,那如果我们把DISTINCTdepartment_id放在前面呢,这样靠谱吗,那你可能会觉得前面12条后面107条那不是还是不对吗,其实这里是这样解释的,因为DISTINCT它不仅仅考虑了部门id的去重还考虑了salary去重,代表就是不同部门里的不同工资的情况.

它仅仅是没有报错,但是没有实际意义

SELECT DISTINCT department_id,salary FROM employees;

查了个寂寞.

空值是什么,是否参与运算

,就是我们刚才NULL那个字段的记录值,我们奖金率这个字段就有很多员工是空值.那么我们考虑一个事情

空值是否参与运算,null和0和''这个有什么关系我们要知道null是不等同的.就像我们有一个字段员工id是null,代表的就是不知道他的id,如果你写了0,那么就把这个人仍到部门,null代表的是不清楚,不是0.空值如果参与运算会是什么效果呢.那我们算一下员工的年工资.

SELECT employees_id,salary "月工资",salary*(1+commission_pct)*12 AS "年工资" FROM employees;

这里我们发现没有报错,但是明明有月工资却年工资是空的,就感觉不太对,有些字段就有值,有些就没值.

这是为什么,我们把奖金率也加入大家就找到原因了

我们会发现奖金率是空的时候,年工资也是空的,所以只要空值加入运算,结果就是空值,这是我们实际演示计算出来的,另外大家可能想把奖金率当成0来计算,这就陷入陷阱了,我们说空不等于0.,我们想做这种运算那就要用到一个函数ifnull(commission_PCT,0),这个我们后面再说

这是我们实际问题的解决方案,之后我们说到单行函数的时候会说.

接着我们看下个问题

着重号

我们如果想查询应该表,表名叫ORDER,我们就直接用SELECT * FROM order

这时候我们就会发现他会报错,order是不是有点特别,他order代表的其实是关键词排序,那么系统就会认为这是一个关键字,那么我们就要用着重号,我们的表名和字段不要用系统字段和数据库系统的常用方法冲突,如果坚持使用,要使用符合着重号,也就是键盘数字1旁边的那个符号`包裹起来

既然目前生米已经煮成熟饭了,我们就要使用着重号了.

一般我们是不加着重号了,但是如果涉及关键词的时候,一定要使用着重号.

查询常数

这个是什么东西呢 我们要建立一个常数列的话.

比如SELECT '晴天',employee_id,salary FROM employees;

这时你可能会想,那我们晴天不是只有一列,而其他字段有107列,不是就会报错吗,我们运行看看

常数是会对每一列都进行匹配.

显示表结构

DESCRIBE这个单词是不是大家初中都学过,是描述的意思,

我们运算DESCRIBE employees;

就会出现一个表,用来描述我们表的结构.

显示表中字段的详细信息.

第一列就是字段的名字,type是字段的类型,null代表是否可以为空,key代表约束,后面我们会讲到,default代表的是默认值

desc也是可以显示结构,代表的就是DESCRUIBE的缩写.

简单小结:

SELECT * FROM 表名这是我们查询语句

列的别名,在字段后加空格或者AS在加别名,就可以修改结果的别名

去重:在SELECT后面加DISTINCT就可以去重

空值是可以参与运算的,但是参与运算的结果全为空

着重号:当关键词变成字段名或者记录值时,我们可以yon``把它包裹起来

重要结构:过滤数据:

现在我们想要查询有些满足条件的条数,比如我们现在想查询90号部门的信息

SELECT * FROM employees WHERE department_id = 90;这里的where代表的就是条件,后面跟着我们需要的限制条件,现在我们就运行试一试

这样我们就把部门是90号的全部信息调用出来了

练习,我们想查询last_name叫做king的员工信息:

SELECT * FROM employees WHERE last_name='king';

这里我们就查询出来了,但是里面有几个问题,需要注意,我们就一并讲了,不用做自己去摸索.

我们说windows里面大小写是不敏感的我们搜小写的king,会出现大写的King,我们也是可以查询出来的.但是这里windows就不背锅了,其实真正原因是因为mysql不严谨导致的,我们换一个场景试一试,我们用oracle:King是不是可以查询出来

如果我们查询的是小写的king就不会查询出记录

而且我们用""来包裹字符串,是不是也会出现报错

还有一件事,我们的where是必须紧跟在FROM语句的后面,是不能在其他的语句后面的,他俩必须挨着,我们不仅可以用=,还能用><的各种运算符,我们下次再说.

各位也去练习练习,我们的SELECT * FROM 表语句,有AS,DISTINCT,DESC,WHERE关键词.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2119920.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MyBaits的初理解

一.Mybaits的简介 Mybaits就是对JDBC的简化&#xff0c;就是对持久化的实现。 二.基础 需要导的dependencies <dependencies><!-- mybatis依赖 --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId>&l…

第 5 章多视图几何

本章讲解如何处理多个视图&#xff0c;以及如何利用多个视图的几何关系来恢复照相机位置信息和三维结构。通过在不同视点拍摄的图像&#xff0c;我们可以利用特征匹配来计算出三维场景点以及照相机位置。本章会介绍一些基本的方法&#xff0c;展示一个三维重建的完整例子&#…

获取多行文本内容,去掉首尾空格、去掉空字符串,解析为文本数组

核心代码 // 获取多行文本内容&#xff0c;去掉首尾空格、去掉空字符串&#xff0c;解析为文本数组 getMultiLineTexts(textareaValue) {return textareaValue.split("\n").map((v) > v.split("\t").join("").trim()).filter((v, i, ar) &g…

Qt | ubuntu20.04安装Qt6.5.3并创建一个example完整教程(涉及诸多开发细节,商用慎重)

点击上方"蓝字"关注我们 01、下载 >>> 下载Qt在线安装包 这里采用镜像地址进行下载,避免网络过慢。 镜像地址:http://mirrors.ustc.edu.cn/qtproject/archive/online_installers/4.5/ 选择最新版本下载,如截至目前最新版本为qt-unified-linux-x64-4.5.2…

“探索数字孪生技术:细数其在各行业的实际应用场景“

数字孪生城市是指在数字世界中创建一个同物理实体城市外观一致、行动一致、思想一致的 数字虚拟城市&#xff0c;实现对现实世界的监测、诊断、回溯、预测和决策控制&#xff0c;用于实体城市的规划、建设、 治理和优化等全生命周期管理&#xff0c;提高城市运行效率和市民居住…

内网穿透的应用-Deepin系统安装x11vnc实现任意设备无公网IP远程连接Deepin桌面

文章目录 前言1. 安装x11vnc2. 本地远程连接测试3. Deepin安装Cpolar4. 配置公网远程地址5. 公网远程连接Deepin桌面6. 固定连接公网地址7. 固定公网地址连接测试 前言 本文主要介绍在Deepin系统中安装x11vnc工具&#xff0c;并结合Cpolar内网穿透工具实现任意设备无公网IP也可…

计算机毕业设计Pyhive+Spark招聘可视化 职位薪资预测 招聘推荐系统 招聘大数据 招聘爬虫 大数据毕业设计 Hadoop Scrapy

《SparkHive招聘推荐与预测系统》开题报告 一、引言 随着互联网技术的飞速发展&#xff0c;招聘行业积累了大量的数据&#xff0c;包括职位信息、应聘者信息、企业信息等。这些数据中蕴含着丰富的价值&#xff0c;能够帮助企业和求职者更好地匹配&#xff0c;提高招聘效率。然…

浮点数精度问题

为什么会产生精度问题&#xff1f; 我们带着这个问题去探寻浮点数二进制的存储原理 浮点数是怎么存在计算机中的&#xff1f; 浮点数在计算机中的表示通常遵循IEEE 754标准。其基本概念如下&#xff1a; 结构&#xff1a;浮点数由三部分组成&#xff1a; 符号位&#xff08;…

Android主副屏显示-Android13

Android主副屏显示-Android13 1、DisplayDeviceInfo屏幕信息2、LogicalDisplay.java2.1 configureDisplayLocked刷新 DisplayManagerService启动及主屏添加-Android13 1、DisplayDeviceInfo屏幕信息 DisplayManagerService启动及主屏添加-Android13 中监听获取&#xff0c;在L…

Vue3+ElementPlus 封装图片空间组件的门面

什么是图片空间? 图片空间就是专门管理我们上传图片的地方。就好比用户管理一样&#xff0c;我们对要上传的图片进行管理。 这样做的好处有哪些&#xff1f; 我们把可能需要的图片都上传到图片管理中。在其他需要图片的地方&#xff08;如&#xff1a;商品图片等&#xff09;可…

【MATLAB】FIR滤波器的MATLAB实现

FIR滤波器的MATLAB实现 FIR滤波器的设计fir1函数fir2函数 与IIR滤波器相比&#xff0c;FIR滤波器既有其优势也有其局限性。FIR滤波器的主要优点包括&#xff1a; 精确的线性相位响应&#xff1b;永远保持稳定性&#xff1b;设计方法通常是线性的&#xff1b;在硬件实现中具有更…

Open CASCADE学习|按圆离散旋转体

旋转体是一个非常重要的概念&#xff0c;它涉及到三维空间中由二维曲线绕某一轴线旋转形成的立体形状。这种旋转体的形成过程&#xff0c;实际上是一个连续变化的动态过程&#xff0c;但在数学和几何学中&#xff0c;我们往往通过静态的方式来描述和研究它。 旋转体的基本特性…

中电金信智能视觉分析系统,以AI技术助力企业升级

基于行业需求与业务痛点&#xff0c;中电金信推出了智能视觉分析系统。该系统是集视频接入、视频识别与分析、AI算法管理、异常报警等为一体&#xff0c;可提供视频安全监管标准的场景应用方案以及二次开发能力的通用智能视觉分析系统。该系统拥有强大的监控摄像头设备接入能力…

EFI引导模式下配置Windows和Linux双系统共存

这几天在VirtualBox虚机里玩Modular MAX下的LLama3大模型&#xff0c;实在受不了这执行速度&#xff0c;于是下决心把Ubuntu系统安装在硬盘上跟Windows11做双系统共存。之前在传统BIOS引导模式下做过不少次双系统引导&#xff0c;EFI模式下第一次做&#xff0c;加之windows系统…

【JavaSE】--数据类型与变量

文章目录 1. 字面常量2. 数据类型3. 变量3.1 变量概念3.2 整型变量3.2.1 整型变量3.2.2 长整型变量3.2.3 短整型变量3.2.4 字节型变量 3.3 浮点型变量3.3.1 双精度浮点型3.3.2 单精度浮点型 3.4 字符型变量3.5 布尔型变量3.6 类型转换3.6.1 自动类型转换&#xff08;隐式&#…

Openeuler22 部署 RackTables0.22.0

目录 0、前言 一、部署lamp环境&#xff0c;lamp环境测试 1、部署Apache&#xff0c;apache环境测试 2、部署php、mysql&#xff0c;php环境测试 二、放文件 三、配置mysql 四、安装racktables 第一步、点击proceed继续 第二步、点击proceed 第三步、根据提示进行操作…

【Qt】解决设置QPlainTextEdit控件的Tab为4个空格

前言 PyQt5 是一个用于创建跨平台桌面应用程序的 Python 绑定集合&#xff0c;它提供了对 Qt 应用程序框架的访问。用于开发具有图形用户界面&#xff08;GUI&#xff09;的应用程序&#xff0c;以及非GUI程序。PyQt5 使得 Python 开发者可以使用 Qt 的丰富功能来构建应用程序。…

【无线通信发展史⑨】1791年路易吉·伽伐尼-关于动物电的研究与1800年亚历山大·伏打伯爵-电池:伏打电池

前言&#xff1a;用这几个问答形式来解读下我这个系列的来龙去脉。如果大家觉得本篇文章不水的话希望帮忙点赞收藏加关注&#xff0c;你们的鼓舞是我继续更新的动力。 我为什么会写这个系列呢&#xff1f; 首先肯定是因为我本身就是一名从业通信者&#xff0c;想着更加了解自己…

RHEL 7 安装配置( Linux 网络操作系统 02)

一、虚拟机安装 我们的每台电脑都已经安装了VMware 虚拟机&#xff0c;其安装相当简单&#xff0c;在此不再赘述。可以参考如下链接&#xff1a; VMWare安装傻瓜式教程 &#xff08;大家可以关注老师的博客&#xff0c;也建议大家写博客。&#xff09; 二、红帽 rhel 7 安装 找…

Windows系统Docker部署AList并挂载阿里云盘实现远程访问详细教程——“cpolar内网穿透”

文章目录 前言1. 使用Docker本地部署Alist1.1 本地部署 Alist1.2 访问并设置Alist1.3 在管理界面添加存储 2. 安装cpolar内网穿透3. 固定Alist公网地址 前言 本文和大家分享如何在Windows系统使用Docker本地部署Alist全平台网盘神器&#xff0c;然后结合cpolar内网穿透工具实现…