SELECT语句

SELECT语句

前言:

在我们MySQL中,数据的存储是类似于EXCEL的,是以表格的形式存在的,所以都是一行一行的数据或者是一个一个的数据。
我们可以非常形象的理解一下,每一**列(column)都是一个对象的属性,每一行(row)**都是一个对象的实例,我们要查询的话通过SELECT查到我们想要知道的数据,通过行我们可以知道想要查询的行的数据。

1.0 SELECT

#没有任何子句
SELECT 1;
#没有任何子句
SELECT 9/2;

1.1 SELECT…FROM

  • 语法:
SELECT    #标识选择哪些列
FROM      #标识从哪个表中选择
  • 选择全部列:
SELECT *           # * 标识选择所有列
FROM departments;  # 选择departments表

一般情况下,除非需要使用表中的所有字段数据,最好不要使用通配符 ’ * '。使用通配符虽然可以节省输入查询语句的时间,但是获取不需要的列数据通常会降低查询和所使用的应用程序的效率。通配符的优势是,当不知道所需要的列的名称时,可以通过它获取它们。

在生产环境下, 不推荐你直接使用 SELECT * 进行查询。

  • 选择特定的列(想要查询的数据类型):
SELECT department_id, location_id
FROM departments;

MySQL中的SQL语句是不区分大小写的,因此SELECT和select的作用是相同的,但是,许多开发人员习惯将关键字大写,数据列和表名小写,读者也应该养成一个良好的编程习惯,这样子写出来的代码更容易阅读和维护。

(但是我就因为命令行,也因为
Windows不区分大小写,所以养成了小写的坏习惯)。

1.2 列的别名

  • 重命名一个列
  • 便于计算
  • 紧跟列明,也可以在列名和列名之间查润关键字 AS, 别名使用双引号, 以便在别名中包含空格或特殊的字符并区分大小写。
  • AS可以省略。
  • 建议别名简短,见名知意
  • for example
SELECT last_name AS name, commission_pct comm
FROM employees;

1.3 去除重复行

默认情况下,查询会返回满足条件的所有行,包括重复行 (这几行内容都是一样的)

在SELECT语句中使用关键字DISTINCT去除重复行

SELECT DISTINCT department_id
FROM employees;

这个DISTINCT关键字在SELECT中一调用,就可以去除查询结果的重复元素了,下面我们详细说一下DISTINCT的用法和注意事项。

#去除单列中的重复元素。
SELECT DISTINCT department_id
FROM employees;#不能用这种写法,去除多列中单列的重复元素
SELECT department_id, DISTINCT last_name
FROM employees;#不可以把DISTINCT放中间,要放到所查字段的开头。#去除多列重复元素
SELECT DISTINCT department_id, last_name
FROM employees;#这种去重是按所查字段都相同才去重,只要有一个字段不相同,就不会去重。

1.4 空值参与运算

  • 所有运算符或列值遇到null值,运算的结果都为null
SELECT employee_id, salary, commission_pct, 12 * salary * (1 + commission_pct) as "annual_sal"
FROM employees;

这里你一定要注意,在MySQL里面,空值不等于空字符串。一个空字符串的长度是0, 而一个空值的长度是空。而且,在MySQL里面,空值是占用空间的

1.5 着重号

这个符号之前也提到过,这个是如果字段名,变量名之类的名字和关键字重复了,但是你有不想换名字,就可以给名字用` `引起来,这样子就相当于告诉MySQL,我们这个不是关键字。

#错误的
SELECT *
FROM ORDER;#正确的
SELECT *
FROM `ORDER`;
  • 结论
    我们需要保证表中的字段,表名等没有和MySQL自带的名字起冲突,如果字体颜色变了,那就说明冲突了,就可以用着重号引起来。

2. 显示表结构

使用DESCRIBEDESC命令,表示表结构

DESCRIBE employees;
或
DESC employees;

通过显示表结构的语句,我们可以得到一个表格,我们来大概解释一下

FieldTypeNullKeyDefaultExtra
字段名称字段类型是否可以存储Null值表示是否已经编制索引,PRI表示该列是表主键的一部分,UNI表示被UNIQUE修饰,只能出现一次,MUL表示某个给定值可出现多次表示该列是否有默认值,如果有的话,值是多少表示可以获取的与给定列有关的信息

3.WHERE过滤器

这个相当于筛选我们想要查找的数据,写在FROM下方

SELECT *
FROM employees
WHERE id = 1002;

4.结语

这就是我的理解了,虽然名字叫SELECT语句,但是没有涉及到SELECT的难点,先浅浅说一下SELECT的用法,重点是其他知识点的铺垫,理解了其他的知识点,对之后的学习有不小帮助。

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

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

相关文章

免费【2024】springboot 必录德健身器材用品网的设计与实现

博主介绍:✌CSDN新星计划导师、Java领域优质创作者、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流✌ 技术范围:SpringBoot、Vue、SSM、HTML、Jsp、PHP、Nodejs、Python、爬虫、数据可视化…

使用 Docker 快速入门 RabbitMQ:安装与基本操作

引言 RabbitMQ 是一个流行的开源消息代理软件,它支持多种消息协议,并且易于部署和使用。Docker 作为一个轻量级容器化平台,可以简化 RabbitMQ 的安装和部署过程。本文将引导你通过 Docker 快速安装 RabbitMQ,并进行一些基本操作。…

在 `JDK 17` 中使用反射

在 JDK 17 中使用反射的基本步骤如下&#xff1a; 步骤一&#xff1a;导入相关类 import java.lang.reflect.Field; import java.lang.reflect.Method; import java.lang.reflect.Constructor;步骤二&#xff1a;获取类对象 // 通过类的全限定名获取 Class 对象 Class<?&…

性能对比:Memcached 与 Redis 的关键差异

性能对比&#xff1a;Memcached 与 Redis 的关键差异 在选择合适的缓存系统时&#xff0c;Memcached 和 Redis 是最常被提及的两种技术。它们都是内存存储系统&#xff0c;用于提高数据访问速度和应用性能。尽管它们在功能上有很多相似之处&#xff0c;但在性能、特性和应用场…

java面向对象进阶进阶篇--《包和final》

一、前言 今天还是面向对象相关知识点的分享&#xff0c;包是写小型项目时不可或缺的存在&#xff0c;final关键字用的地方不算太多。idea会提示我们导包&#xff0c;有时会自动导包&#xff0c;确实十分方便。但是我们也不能不会自己去导包。 面向对象篇不出意外的话本周就要…

22集 如何minimax密钥和groupid-《MCU嵌入式AI开发笔记》

22集 如何获取minimax密钥和groupid-《MCU嵌入式AI开发笔记》 minimax密钥获取 https://www.minimaxi.com/platform 进入minimax网站&#xff0c;注册登录后&#xff0c;进入“账户管理”&#xff0c; 然后再点击“接口密钥”&#xff0c;然后再点击“创建新的密钥”。 之…

如何使用aiohttp或requests-async等库并发地执行多个HTTP请求

在Python中&#xff0c;要并发地执行多个HTTP请求&#xff0c;可以使用aiohttp这样的异步HTTP客户端库&#xff0c;因为它支持异步编程&#xff0c;能够显著提高IO密集型任务的性能&#xff0c;比如网络请求。requests-async并不是一个广泛认知的库&#xff08;虽然可能存在类似…

《0基础》学习Python——第十九讲__爬虫/<2>

一、用get请求爬取一般网页 首先由上节课我们可以找到URL、请求方式、User-Agent以及content-type 即&#xff1a;在所在浏览器页面按下F12键&#xff0c;之后点击网路-刷新&#xff0c;找到第一条双击打开标头即可查看上述所有内容&#xff0c;将上述URL、User-Agent所对应的…

1.6、计算机系结构

Flynn分类法 Flynn分类法是1966年&#xff0c;M. J. Flynn提出的根据指令流、数据流的多倍性特征对计算机系统的分类方法。 指令流为机器执行的指令序列。数据流是由指令调用的数据序列。包括输入数据和中间结果&#xff0c;不包括输出数据 分类 Flynn把计算机系统的结构分…

初学MWA(Modern Web App)那些事-3-做一个简单的计算器

初学MWA(Modern Web App&#xff09;那些事-3-做一个简单的计算器 目录 初学MWA(Modern Web App&#xff09;那些事-3-做一个简单的计算器前言一、本节学习目标二、计算器实例项目创建过程2.1 创建一个HTML文档2.2 查看新建的html文档2.3 Web应用开发&#xff1a;初始化设置2.4…

linux C++ onnxruntime yolov8 视频检测Demo

linux C onnxruntime yolov8 视频检测Demo 目录 项目目录 效果 ​编辑CMakeLists.txt 代码 下载 项目目录 效果 ./yolov8_demo --help ./yolov8_demo -c2 -ptrue ./yolov8_demo -c1 -strue CMakeLists.txt # cmake needs this line cmake_minimum_required(VERSION 3…

AMD EPYC处理器性能宣称远超Nvidia Grace CPU

AMD近期发布了一份博客文章&#xff0c;其中对比了其EPYC处理器与Nvidia Grace Hopper Superchip&#xff08;基于Arm架构的72核CPU&#xff09;在一系列基准测试中的性能&#xff0c;声称EPYC处理器在多种工作负载下的表现最多可高出两倍。这一比较突显了AMD在数据中心CPU市场…

Covalent(CXT)运营商网络规模扩大 42%,以满足激增的需求

Covalent Network&#xff08;CXT&#xff09;是领先的人工智能模块化数据基础设施&#xff0c;网络集成了超过 230 条链并积累了数千名客户&#xff0c;目前 Covalent Network&#xff08;CXT&#xff09;网络迎来了五位新运营商的加入&#xff0c;包括 Graphyte Labs、PierTw…

使用PicGo操作gitee图床(及web端html不能访问图片的解决办法)

1.新建仓库 2.输入仓库名称,也就是图床名称,必须设置开源可见 也可以在创建仓库后,点击管理->基本信息->是否开源进行设置 鼠标悬浮到右上角头像->设置 点击私人令牌 点击生成新令牌,填写描述,直接点提交即可 点击提交后输入登录密码会生成一个token秘钥,如下,这个…

【C++】——初识模版

文章目录 前言函数模版函数模版的原理函数模版的实例化 类模版类模版的实例化 前言 当我们使用一个通用的函数&#xff1a; //为每一个类型都编写一个重载版本 void Swap(int& left, int& right) {int temp left;left right;right temp; } void Swap(double& …

【Linux】执行命令提示:-bash: !@#‘“: event not found

问题描述 在Linux下执行命令时&#xff0c;提示&#xff1a;-bash: xxx event not found&#xff0c;是因为一些特殊字符无法&#xff0c;无法识别 博主是在使用Docker启动xxl-job-admin时&#xff0c;由于设置的-e 数据库密码参数时&#xff0c;存在特殊字符&#xff0c;导致…

在Linux、Windows和macOS上释放IP地址并重新获取新IP地址的方法

文章目录 LinuxWindowsmacOS 在Linux、Windows和macOS上释放IP地址并重新获取新IP地址的方法各有不同。以下是针对每种操作系统的详细步骤&#xff1a; Linux 使用DHCP客户端&#xff1a;大多数Linux发行版都使用DHCP&#xff08;动态主机配置协议&#xff09;来自动获取IP地址…

七、系统配置与性能评价(考点篇)

1 性能指标 性能指标&#xff0c;是软、硬件的性能指标的集成。在硬件中&#xff0c;包括计算机、各种通信交换设备、各类网 络设备等&#xff1b;在软件中&#xff0c;包括&#xff1a;操作系统、协议以及应用程序等。 1.计算机 对计算机评价的主要性能指标有&#xff1a; 时…

【嵌入式开发之数据结构】树的基本概念、逻辑结构和四种常用的遍历算法及实现

树&#xff08;Tree&#xff09;的定义及基本概念 树的定义 树(Tree)是个结点的有限集合T&#xff0c;它满足两个条件&#xff1a; 有且仅有一个特定的称为根&#xff08;Root&#xff09;的节点&#xff1b;其余的节点分为个互不相交的有限合集&#xff0c;其中每一个集合又…

日常开发记录分享——C#控件ToolTip实现分栏显示内容

文章目录 需求来源实现思路实施请看VCR等等别走&#xff0c;有优化 需求来源 需要在鼠标浮动到指定位置后提示出详细的信息&#xff0c;一开始使用的tooltip实现&#xff0c;但是里面的内容效果并不理想&#xff0c;需要有条理性&#xff0c;于是就想到能不能将展示的东西分列…