MySQL 03 章——基本的SELECT语句

一、SQL概述

(1)SQL背景知识

  1. SQL(Structured Query Language,结构化查询语言)是使用关系模型的数据库应用语言,与数据直接打交道
  2. 不同的数据库管理系统生产厂商都支持SQL语句,但都有特有内容

(2)SQL语言排行榜

  1. 自从SQL加入了TIOBE编程语言排行榜,就一直保持在Top10

(3)SQL分类

SQL语言在功能上主要分为三大类:

  1. DDL(Data Definition Language,数据定义语言):这些语句定义了不同的数据库、表、视图、索引等数据库对象,还可以用来创建、删除、修改数据库和数据表的结构(CREATE\ALTER\DROP\RENAME\TRUNCATE)

  2. DML(Data Manipulation Language,数据操作语言):用于添加(INSERT)、删除(DELETE)、更新(UPDATE)和查询(SELECT)数据库记录,并检查数据的完整性

  3. DCL(Data Control Language,数据控制语言):用于定义数据库、表、字段、用户的访问权限和安全级别(COMMIT\ROLLBACK\SAVEPOINT\GRANT\REVOKE)

二、SQL语言的规则与规范

(1)基本规则

  1. SQL可以写在一行或者多行,为了提高可读性,各子句分行写,必要时使用缩进
  2. 每条命令以;或\g或\G结尾
  3. 关键字不能被缩写也不能分行
  4. 关于标点符号:
    1. 必须保证所有的()、单引号、双引号是成对结束的
    2. 必须使用英文状态下的半角输入方式
    3. 字符串型日期时间类型的数据可以使用单引号表示
    4. 列的别名,尽量使用双引号,而且不建议省略as

(2)SQL大小写规范

  1. MySQL在Windows环境下是大小写不敏感的
  2. MySQL在Linux环境下是大小写敏感的
    1. 数据库名、表名、表的别名、变量名是严格区分大小写的
    2. 关键字、函数名、列名(字段名)、列的别名(字段的别名)是忽略大小写的
  3. 推荐采用统一的书写规范:
    1. 数据库名、表名、表别名、字段名、字段别名都小写
    2. SQL关键字、函数名、绑定变量都大写

(3)注释

  1. 单行注释:#注释文字(MySQL特有的方式)
  2. 单行注释:-- 注释文字(--后面必须包含一个空格)
  3. 多行注释:/*注释文字*/

(4)命名规则(暂时了解)

  1. 数据库名、表名不得超过30个字符,变量名限制为29个字符
  2. 必须只能包含A-Z、a-z、0-9、_共63个字符
  3. 数据库名、表名、字段名等对象名中间不要包含空格
  4. 同一个MySQL软件中,数据库不能同名;同一个库中,表不能重名;同一个表中,字段不能重名
  5. 必须保证你的字段没有和保留字、数据库系统或常用方法冲突。如果坚持使用,请在SQL语句中使用`(着重号)引起来
  6. 保持字段名和类型的一致性

(5)数据导入指令

  1. 方式一:source 文件的全路径名(在命令行界面下)
  2. 方式二:基于具体的图形化界面

三、基本的SELECT语句

(1)SELECT

  1. 最基本的SELECT语句
  2. DUAL是一个伪表

(2)SELECT...FROM

  1. SELECT 字段1,字段2,... FROM 表名;
  2. *代表表中所有字段

(3)列的别名

  1. 重命名一个列(只在显示的结果中起作用,并不改变列本身的名字)
  2. 便于计算
  3. 紧跟列名,也可以在列名和列的别名之间加入关键字AS,别名使用双引号,以便在别名中包含空格或特殊字符,并区分大小写
  4. AS可以省略
  5. 建议别名简短,见名知意
  6. 举例

(4)去除重复行

  1. 默认情况下,查询会返回全部行,包括重复行
  2. 用distinct去重后的结果(即先把这一列查询出来,然后去除重复的)
  3. 错误的:
  4. 注意(此时二者都相同,才算重复):

(5)空值参与运算

  1. 所有运算符或列值遇到null值,运算结果都为null
  2. null不等同于0,' ','null'
  3. 空值参与运算

(6)着重号

  1. 表名已经与关键字冲突,如果我们还想查询该表格里的数据,就给表名加上一对`(即着重号)

(7)查询常数

  1. 如果查询的不是字段名,那么它就会被当成字段名,查询结果是计算后的
  2. 如果查询内容中有字段名,那么这个整体也会被当成字段名,查询结果是计算后的
  3. 也就是说,我们查询什么,什么就被当作字段名,结果是计算后的

四、显示表结构

  1. 用DESCRIBE关键字
  2. 或者使用DESCRIBE的缩写DESC 

五、过滤数据

  1. 用WHERE关键字接过滤条件:
  2. 字符串要加单引号,别名是加双引号
  3. 在Windows下不区分大小写(但是MySQL不严谨,字符串里也不区分大小写,所以King和king效果一样)

六、课后练习

  1. 查询员工12个月的工资总和,并起名为ANNUAL_SALARY
  2.  查询employees表中去除重复的job_id后的数据
  3. 查询工资大于12000的员工姓名和工资
  4. 查询员工号为176的员工的姓名和部门号
  5. 显示表departments的结构,并查询其中的全部数据

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

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

相关文章

[羊城杯 2024]1z_misc

得到FL4G.zip和天机不可泄露.txt文件,其中压缩包需要解压密码: 二十八星宿: 东方苍龙七宿:角、亢、氐、房、心、尾、箕 南方朱雀七宿:鬼、井、柳、星、张、翼、轸 西方白虎七宿:奎、娄、胃、昴、毕、觜、…

QT----------多媒体

实现思路 多媒体模块功能概述: QT 的多媒体模块提供了丰富的功能,包括音频播放、录制、视频播放和摄像头操作等。 播放音频: 使用 QMediaPlayer 播放完整的音频文件。使用 QSoundEffect 播放简短的音效文件。 录制音频: 使用 QMe…

云计算学习架构篇之HTTP协议、Nginx常用模块与Nginx服务实战

一.HTTP协议讲解 1.1rsync服务重构 bash 部署服务端: 1.安装服务 [rootbackup ~]# yum -y install rsync 2.配置服务 [rootbackup ~]# vim /etc/rsyncd.conf uid rsync gid rsync port 873 fake super yes use chroot no max connections 200 timeout 600 ignore erro…

《Vue3实战教程》42:Vue3TypeScript 与组合式 API

如果您有疑问&#xff0c;请观看视频教程《Vue3实战教程》 TypeScript 与组合式 API​ 这一章假设你已经阅读了搭配 TypeScript 使用 Vue 的概览。 为组件的 props 标注类型​ 使用 <script setup>​ 当使用 <script setup> 时&#xff0c;defineProps() 宏函数支…

Diffusion Transformer(DiT)——将扩散过程中的U-Net换成ViT:近频繁用于视频生成与机器人动作预测(含清华PAD详解)

前言 本文最开始属于此文《视频生成Sora的全面解析&#xff1a;从AI绘画、ViT到ViViT、TECO、DiT、VDT、NaViT等》 但考虑到DiT除了广泛应用于视频生成领域中&#xff0c;在机器人动作预测也被运用的越来越多&#xff0c;加之DiT确实是一个比较大的创新&#xff0c;影响力大&…

2024年12月 Scratch 图形化(二级)真题解析#中国电子学会#全国青少年软件编程等级考试

Scratch图形化等级考试(1~4级)全部真题・点这里 一、单选题(共25题,共50分) 第 1 题 小猫初始位置和方向如下图所示,下面哪个选项能让小猫吃到老鼠?( ) A. B. C.

LLaMA详解

LLaMA 进化史 大规模语言模型(Large Language Model, LLM)的快速发展正在以前所未有的速度推动人工智能(AI)技术的进步。 作为这一领域的先行者, Meta在其LLaMA(Large Language Model Meta AI)系列模型上取得了一系列重大突破。 近日, Meta官方正式宣布推出LLaMA-3, 作为继LL…

SpringMVC(六)拦截器

目录 1.什么是拦截器 2.拦截器和过滤器有哪些区别 3.拦截器方法 4.单个拦截器的执行流程 5.使用拦截器实现用户登录权限验证&#xff08;实例&#xff09; 1.先在html目录下写一个login.html文件 2.在controller包下写一个LoginController文件 3.加拦截器 1.创建一个conf…

推理加速:投机采样经典方法

一 SpecInfer 基于模型 SpecInfer&#xff08;[2305.09781] SpecInfer: Accelerating Generative Large Language Model Serving with Tree-based Speculative Inference and Verification&#xff09; SpecInfer 投机采样利用多个小型模型&#xff08;SSM&#xff09;快速生…

最好用的图文识别OCR -- PaddleOCR(1) 快速集成

最近在项目中遇到了 OCR 的需求&#xff0c;希望能够实现高效而准确的文字识别。由于预算限制&#xff0c;我并未选择商业付费方案&#xff0c;而是优先尝试了开源工具。一开始&#xff0c;我测试了 GOT-OCR2.0&#xff0c;但由于我的 Mac 配置较低&#xff0c;不支持 GPU 运算…

FFmpeg:详细安装教程与环境配置指南

FFmpeg 部署完整教程 在本篇博客中&#xff0c;我们将详细介绍如何下载并安装 FFmpeg&#xff0c;并将其添加到系统的环境变量中&#xff0c;以便在终端或命令行工具中直接调用。无论你是新手还是有一定基础的用户&#xff0c;这篇教程都能帮助你轻松完成 FFmpeg 的部署。 一、…

Spring SpEL表达式由浅入深

标题 前言概述功能使用字面值对象属性和方法变量引用#this 和 #root变量获取类的类型调用对象(类)的方法调用类构造器类型转换运算符赋值运算符条件(关系)表达式三元表达式Elvis 操作符逻辑运算instanceof 和 正则表达式的匹配操作符 安全导航操作员数组集合(Array 、List、Map…

“AI人工智能软件开发公司:创新技术,引领未来

大家好&#xff01;今天我们来聊聊一个充满未来感的话题——AI人工智能软件开发公司。这个公司&#xff0c;用大白话说&#xff0c;就是专门研究和开发人工智能软件的地方&#xff0c;它们用最新的技术帮我们解决问题&#xff0c;让生活和工作变得更智能、更便捷。听起来是不是…

常见中间件漏洞复现

1.tomcat 1.1 CVE-2017-12615(put上传) 当在Tomcat的conf&#xff08;配置目录下&#xff09;/web.xml配置文件中添加readonly设置为false时&#xff0c;将导致该漏洞产 ⽣&#xff0c;&#xff08;需要允许put请求&#xff09; , 攻击者可以利⽤PUT方法通过精心构造的数据包…

memcached的基本使用

memcached是一种基于键值对的内存数据库&#xff0c;一般应用于缓存数据&#xff0c;提高数据访问速度&#xff0c;减轻后端数据库压力。 安装 这里以Ubuntu为例&#xff0c;其他系统安装方法请看官方文档。 sudo apt-get update sudo apt-get install memcached启动 memca…

Unity2022接入Google广告与支付SDK、导出工程到Android Studio使用JDK17进行打包完整流程与过程中的相关错误及处理经验总结

注&#xff1a;因为本人也是第一次接入广告与支付SDK相关的操作&#xff0c;网上也查了很多教程&#xff0c;很多也都是只言片语或者缺少一些关键步骤的说明&#xff0c;导致本人也是花了很多时间与精力踩了很多的坑才搞定&#xff0c;发出来也是希望能帮助到其他人在遇到相似问…

C++11右值与列表初始化

1.列表初始化 C98传统的{} C98中一般数组和结构体可以用{}进行初始化。 struct Point {int _x;int _y; }; int main() {int array1[] { 1, 2, 3, 4, 5 };int array2[5] { 0 };Point p { 1, 2 };return 0; } C11中的{} C11以后统一初始化方式&#xff0c;想要实现一切对…

单片机复位电路基本理解教程文章·含上拉电阻理解电容开路理解!!!

目录 常见复位电路种类 复位电路电阻上拉理解 电容储能断路理解 ​​​​​​​ ​​​​​​​ 编写不易&#xff0c;仅供学习&#xff0c;请勿搬运&#xff0c;感谢理解 常见元器件驱动电路文章专栏连接 LM7805系列降压芯片驱动电路降压芯片驱动电路详解-…

【大模型系列】Mobile-Agent(2024.04)

Paper: https://arxiv.org/pdf/2401.16158Github: https://github.com/X-PLUG/MobileAgentAuthor: Junyang Wang et al. 北交、阿里巴巴 Mobile-agent核心工作&#xff1a; 首先使用视觉感知工具(检测和OCR模型)识别前端界面中文本和图像元素的精确位置 检测图标&#xff1a;…

Android Studio学习笔记

01-课程前面的话 02-Android 发展历程 03-Android 开发机器配置要求 04-Android Studio与SDK下载安装 05-创建工程与创建模拟器