MySQL:MySQL的查询(上)

news2024/11/24 5:33:11

文章目录

  • MySQL的增加
    • 单行数据插入
    • 多行数据插入
    • 插入否则更新
    • 替换
  • MySQL的查询
    • select列
    • where语句

本篇开始总结的是MySQL当中的基本查询语句

对于数据库的查询,无非大致就是增删查改,因此对于这些内容进行一一解释:

MySQL的增加

单行数据插入

mysql> create table students ( id int unsigned primary key auto_increment, name
 varchar(20) not null, qq varchar(20) );
Query OK, 0 rows affected (0.12 sec)

mysql> desc students;
+-------+--------------+------+-----+---------+----------------+
| Field | Type         | Null | Key | Default | Extra          |
+-------+--------------+------+-----+---------+----------------+
| id    | int unsigned | NO   | PRI | NULL    | auto_increment |
| name  | varchar(20)  | NO   |     | NULL    |                |
| qq    | varchar(20)  | YES  |     | NULL    |                |
+-------+--------------+------+-----+---------+----------------+
3 rows in set (0.04 sec)

mysql> insert into students (name, qq) values ('小明', '123321');
Query OK, 1 row affected (0.01 sec)

mysql> insert into students  values (2, '小红', '1123321');
Query OK, 1 row affected (0.01 sec)

mysql> select * from students;
+----+--------+---------+
| id | name   | qq      |
+----+--------+---------+
|  1 | 小明   | 123321  |
|  2 | 小红   | 1123321 |
+----+--------+---------+
2 rows in set (0.00 sec)

在增加这个方面没有什么需要注意的,更多需要注意的是全列插入还是单列插入,如果指定了内容就是单列插入,如果在values前没有指定具体的内容,那就是全列插入

多行数据插入

insert语句也支持多行数据插入:

mysql> insert into students (name, qq) values ('小刚', 3333), ('小亮', 4444444);
Query OK, 2 rows affected (0.00 sec)
Records: 2  Duplicates: 0  Warnings: 0

mysql> select * from students;
+----+--------+---------+
| id | name   | qq      |
+----+--------+---------+
|  1 | 小明   | 123321  |
|  2 | 小红   | 1123321 |
|  3 | 小刚   | 3333    |
|  4 | 小亮   | 4444444 |
+----+--------+---------+
4 rows in set (0.01 sec)

插入否则更新

在前面的学习中也知道了主键和唯一键,正常来说如果插入相同的数据到这当中是会提示有错误的信息的,为了方便描述更改一下列的信息:

mysql> alter table students add unique (qq);
Query OK, 0 rows affected (0.09 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> desc students;
+-------+--------------+------+-----+---------+----------------+
| Field | Type         | Null | Key | Default | Extra          |
+-------+--------------+------+-----+---------+----------------+
| id    | int unsigned | NO   | PRI | NULL    | auto_increment |
| name  | varchar(20)  | NO   |     | NULL    |                |
| qq    | varchar(20)  | YES  | UNI | NULL    |                |
+-------+--------------+------+-----+---------+----------------+
3 rows in set (0.00 sec)

进行主键和唯一键重复更新

mysql> select * from students;
+----+--------+---------+
| id | name   | qq      |
+----+--------+---------+
|  1 | 小明   | 123321  |
|  2 | 小红   | 1123321 |
|  3 | 小刚   | 3333    |
|  4 | 小亮   | 4444444 |
+----+--------+---------+
4 rows in set (0.00 sec)

mysql> insert into students (id, name, qq) values (1, '小纯', 123321);
ERROR 1062 (23000): Duplicate entry '1' for key 'students.PRIMARY'
mysql> insert into students (id, name, qq) values (1, '小纯', 123321) on duplicate key update id=1, name='小纯',qq=123321;
Query OK, 2 rows affected (0.01 sec)

mysql> select * from students;
+----+--------+---------+
| id | name   | qq      |
+----+--------+---------+
|  1 | 小纯   | 123321  |
|  2 | 小红   | 1123321 |
|  3 | 小刚   | 3333    |
|  4 | 小亮   | 4444444 |
+----+--------+---------+
4 rows in set (0.00 sec)

从上面所示的示意可以看出这两个的关系,当主键或者唯一键发生重复后,执行后面的语句可以直接进行替换

但是这样的方法还是比较繁琐,因为在MySQL中直接提供了进行替换的sql语句:

替换

mysql> select * from students;
+----+--------+---------+
| id | name   | qq      |
+----+--------+---------+
|  1 | 小纯   | 123321  |
|  2 | 小红   | 1123321 |
|  3 | 小刚   | 3333    |
|  4 | 小亮   | 4444444 |
+----+--------+---------+
4 rows in set (0.00 sec)

mysql> replace into students (id, name, qq) values (1, '小铁', 123321);
Query OK, 2 rows affected (0.01 sec)

mysql> select * from students;
+----+--------+---------+
| id | name   | qq      |
+----+--------+---------+
|  1 | 小铁   | 123321  |
|  2 | 小红   | 1123321 |
|  3 | 小刚   | 3333    |
|  4 | 小亮   | 4444444 |
+----+--------+---------+
4 rows in set (0.00 sec)

值得注意的是,当提示有Query OK, 2 rows affected (0.01 sec),这个2表示的就是有出现冲突的数据,并且发生了替换,这个所谓的2的意思就是删除了之后再重新插入,所以就是表示的是2行数据被修改

MySQL的查询

下面进行的是对于MySQL的查询模块

select列

一般来说尽量不要使用全列查询,因为可能数据量很大,会带来很大的问题,所以通常来说要选择的最好还是指定列

指定列查询

mysql> select id, name from students;
+----+--------+
| id | name   |
+----+--------+
|  1 | 小铁   |
|  2 | 小红   |
|  3 | 小刚   |
|  4 | 小亮   |
+----+--------+
4 rows in set (0.00 sec)

mysql> select name, id from students;
+--------+----+
| name   | id |
+--------+----+
| 小铁   |  1 |
| 小红   |  2 |
| 小刚   |  3 |
| 小亮   |  4 |
+--------+----+
4 rows in set (0.00 sec)

其中这个顺序是可以不保持创建顺序的,因为是对于一列一列的数据进行提取

表达式

在进行查询的时候也可以带有表达式,例如:

mysql> select id * 2 from students;
+--------+
| id * 2 |
+--------+
|      4 |
|      2 |
|      6 |
|      8 |
+--------+
4 rows in set (0.00 sec)

取别名

也可以对新的一列进行重命名的操作

mysql> select id * 2 as newid from students;
+-------+
| newid |
+-------+
|     4 |
|     2 |
|     6 |
|     8 |
+-------+
4 rows in set (0.00 sec)

mysql> select id * 2 newid from students;
+-------+
| newid |
+-------+
|     4 |
|     2 |
|     6 |
|     8 |
+-------+
4 rows in set (0.00 sec)

其中as可以省去

对于结果去重

利用distinct关键字可以对于结果进行去重的操作

mysql> select math from exam_result;
+------+
| math |
+------+
|   90 |
|   90 |
|   90 |
+------+
3 rows in set (0.01 sec)

mysql> select distinct math from exam_result;
+------+
| math |
+------+
|   90 |
+------+
1 row in set (0.03 sec)

where语句

比较运算符:

在这里插入图片描述
结果排序

对于查询出的MySQL结果进行排序,常用的有asc表示升序,desc表示降序,默认采取的是降序排序

mysql> select math from exam_result order by math desc;
+------+
| math |
+------+
|   95 |
|   91 |
|   90 |
|   90 |
|   90 |
|   50 |
+------+
6 rows in set (0.00 sec)

mysql> select math from exam_result order by math asc;
+------+
| math |
+------+
|   50 |
|   90 |
|   90 |
|   90 |
|   91 |
|   95 |
+------+
6 rows in set (0.00 sec)

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

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

相关文章

鸿铭网创88计第49计:2024挂机托管项目, 单号躺赚4000+,无需发作品

项目概述: 这个副业项目极为适合忙碌却希望额外赚钱的伙伴们。核心是与平台合作,提供快手账号用于发布视频,视频中会嵌入推广链接。当有用户通过这些链接下载应用时,我们就能获得拉新佣金。 项目 地 址 : laoa1.cn/…

Json和Qt中Json的使用学习笔记

视频链接 https://www.bilibili.com/video/BV1yf4y1A7ek/?p2&spm_id_frompageDriver&vd_sourcefa4ef8f26ae084f9b5f70a5f87e9e41b Json JSON是在网络传输中常用的数据格式,能将不同类型的数据统一起来,我们在发送数据前将不同类型的数据存入到…

关于Git的一些基础用法

关于Git的一些基础用法 1. 前言2. 使用GitHub/gitee创建项目2.1 创建账号2.2 创建项目2.3 下载仓库到本地2.4 提交代码到远端仓库2.5 查看日志2.6 同步远端仓库和本地仓库 1. 前言 首先说一个冷知识(好像也不是很冷),Linux和git的创始人是同…

c语言多功能计算软件170

定制魏:QTWZPW,获取更多源码等 目录 题目 要求 主要代码片段 题目 设计一个计算器软件,具备如下功能提示界面。 要求 设计出界面,注意界面名称最后为自己的姓名;(20分)能够实现加、减、乘、…

BoostCompass(建立正排索引和倒排索引模块)

阅读导航 一、模块概述二、编写正排索引和倒排索引模块✅安装 jsoncpp✅Jieba分词库的安装1. 代码基本框架2. 正排索引的建立3. 倒排索引的建立 三、整体代码⭕index.hpp 一、模块概述 这个模块我们定义了一个名为Index的C类,用于构建和维护一个文档索引系统。该系…

AI python

AI python 软件方面程序上的人工智能,和物理那种能跑机器人没关系

emmet语法---快速生成css样式

前言 本文是对emmet语法生成css样式的整理,emmet语法就相当于快捷键一样,只需要我们输入简单的缩写,然后按下tab键即可生成麻烦的css代码。 emmet语法生成css代码 其实,特别简单。比html还要简单。 先上案例: 我们输…

ControllerAdvice用法

ControllerAdvice用法 ControllerAdvice是一个组件注解,它允许你在一个地方处理整个应用程序控制器的异常、绑定数据和预处理请求。这意味着你不需要在每个控制器中重复相同的异常处理代码,从而使得代码更加简洁、易于管理。 主要特性 全局异常处理&a…

Python单元测试框架—pytest常用测试报告类型

🍅 视频学习:文末有免费的配套视频可观看 🍅 关注公众号【互联网杂货铺】,回复 1 ,免费获取软件测试全套资料,资料在手,涨薪更快 先前博客有介绍pytest测试框架的安装及使用,现在来聊…

Stacked Hourglass Networks for Human Pose Estimation 用于人体姿态估计的堆叠沙漏网络

Stacked Hourglass Networks for Human Pose Estimation 用于人体姿态估计的堆叠沙漏网络 这是一篇关于人体姿态估计的研究论文,标题为“Stacked Hourglass Networks for Human Pose Estimation”,作者是 Alejandro Newell, Kaiyu Yang, 和 Jia Deng&a…

CADMap3D2024 2023下载地址及安装教程

CAD Map 3D是由Autodesk开发的一款专业的地图制作和GIS(地理信息系统)软件。它是AutoCAD系列软件的一个扩展,提供了一系列特定于地理数据的工具和功能。 CAD Map 3D主要用于处理和管理与地理空间相关的数据,在地图制作、城市规划…

数据结构学习之路--实现带头双向循环链表的详解(附C源码)

嗨嗨大家~本期带来的内容是:带头双向循环链表的实现。在上期文章中我们提到过带头双向循环链表,那么它的实现又是怎样的呢?今天我们来一探究竟! 目录 前言 一、认识带头双向循环链表 1 认识双向链表 2 带头双向循环链表的定…

这 6 个探索性数据分析(EDA)工具,太实用了!

当进行数据分析时,探索性数据分析(EDA)是一个至关重要的阶段,它能帮助我们从数据中发现模式、趋势和异常现象。而选择合适的EDA工具又能够极大地提高工作效率和分析深度。 在本文中,我将介绍6个极其实用的探索性数据分析(EDA)工具&#xff0…

UTONMOS元宇宙游戏特点

在元宇宙的世界里,游戏不再只是一种娱乐方式,而是一种全新的生活体验。UTONMOS元宇宙游戏带你穿越虚拟与现实的边界,开启一段前所未有的冒险之旅。 在这个充满无限可能的UTONMOS元宇宙游戏中,你将成为自己游戏世界的主角。可以自…

Java(多线程)

一、基本概念 进程:一个具有一定独立功能的程序关于某个数据集合的一次运行活动。它是操作系统动态执行的基本单元,在传统的操作系统中,进程既是基本的分配单元,也是基本的执行单元。线程:操作系统中能够进行运算的最…

蓝桥杯 2019 省A 糖果 动态规划/二进制

#include <bits/stdc.h> // 包含标准库中的所有头文件 using namespace std;int main() {int n,m,k; // 定义变量n&#xff08;糖果包数&#xff09;、m&#xff08;口味数&#xff09;、k&#xff08;每包糖果的个数&#xff09;cin>>n>>m>>k; // 输入…

院子里种点什么树风水好呢?

植物本身是一个丰富的生活领域&#xff0c;有着强烈的视觉暗示。其实&#xff0c;在家中养植物&#xff0c;是有许多好处的&#xff0c;它不仅能够装点庭院的环境让家更美丽&#xff0c;还能调节室内的空气质量&#xff0c;对家人的运势也有着非常大的帮助。 不过&#xff0c;并…

Android 四大组件启动

service: startService启动过程分析 - Gityuan博客 | 袁辉辉的技术博客 在整个startService过程&#xff0c;从进程角度看服务启动过程 Process A进程&#xff1a;是指调用startService命令所在的进程&#xff0c;也就是启动服务的发起端进程&#xff0c;比如点击桌面App图标…

Java 中文官方教程 2022 版(四十九)

原文&#xff1a;docs.oracle.com/javase/tutorial/reallybigindex.html JAXB 示例 原文&#xff1a;docs.oracle.com/javase/tutorial/jaxb/intro/examples.html 以下部分描述如何使用包含在 JAXB RI 捆绑包中的示例应用程序。JAXB RI 捆绑包可从jaxb.java.net获取。下载并安装…

华为云配置安全组策略开放端口

&#x1f436;博主主页&#xff1a;ᰔᩚ. 一怀明月ꦿ ❤️‍&#x1f525;专栏系列&#xff1a;线性代数&#xff0c;C初学者入门训练&#xff0c;题解C&#xff0c;C的使用文章&#xff0c;「初学」C &#x1f525;座右铭&#xff1a;“不要等到什么都没有了&#xff0c;才下…