【MySQL】基本查询(1)

这篇具有很好参考价值的文章主要介绍了【MySQL】基本查询(1)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

【MySQL】基本查询(1)

作者:爱写代码的刚子

时间:2024.3.18

前言:本篇博客将会记录表的基本查询,主要是select语句的用法。

表的增删改查

CRUD : Create(创建), Retrieve(读取),Update(更新),Delete(删除)

Create

语法:

INSERT [INTO] table_name
    [(column [, column] ...)]
    VALUES (value_list) [, (value_list)] ...
value_list: value, [, value] ...

into是可以被省略的。

案例:

-- 创建一张学生表
CREATE TABLE students (
  id INT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
  sn INT NOT NULL UNIQUE COMMENT '学号',
  name VARCHAR(20) NOT NULL,
  qq VARCHAR(20)
);
单行数据 + 全列插入
-- 插入两条记录,value_list 数量必须和定义表的列的数量及顺序一致
-- 注意,这里在插入的时候,也可以不用指定id(当然,那时候就需要明确插入数据到那些列了),那么mysql会使用默认的值进行自增。
INSERT INTO students VALUES (100, 10000, '唐三藏', NULL);
Query OK, 1 row affected (0.02 sec)
  
INSERT INTO students VALUES (101, 10001, '孙悟空', '11111'); 
Query OK, 1 row affected (0.02 sec)
-- 查看插入结果
SELECT * FROM students; 
多行数据 + 指定列插入
-- 插入两条记录,value_list 数量必须和指定列数量及顺序一致
INSERT INTO students (id, sn, name) VALUES (102, 20001, '曹孟德'),
(103, 20002, '孙仲谋');
Query OK, 2 rows affected (0.02 sec)
Records: 2  Duplicates: 0  Warnings: 0
  
-- 查看插入结果
SELECT * FROM students;
插入否则更新

由于主键或者唯一键对应的值已经存在而导致插入失败,所以可以选择性的进行同步更新操作语法:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

-- 0 row affected://表中有冲突数据,但冲突数据的值和 update 的值相等
-- 1 row affected:// 表中没有冲突数据,数据被插入
-- 2 row affected:// 表中有冲突数据,并且数据已经被更新
  • 查询受影响的行数:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

替换
-- 主键 或者 唯一键 没有冲突,则直接插入; 
-- 主键 或者 唯一键 如果冲突,则删除后再插入
  
REPLACE INTO students (sn, name) VALUES (20001, '曹阿瞒'); 
Query OK, 2 rows affected (0.00 sec)
  
-- 1 row affected: 表中没有冲突数据,数据被插入 
-- 2 row affected: 表中有冲突数据,删除后重新插入

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

Retrieve

  • 先创建一个表用于之后的测试:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

SELECT 列
全列查询

– 通常情况下不建议使用 * 进行全列查询
– 1. 查询的列越多,意味着需要传输的数据量越大;
– 2. 可能会影响到索引的使用。

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

指定列查询

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

查询字段为表达式

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

为查询结果指定别名

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

  • 当然也可以不带as关键字:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

结果去重
  • distinct关系字

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

WHERE 条件
  • 比较运算符:
运算符 说明
>, >=, <, <= 大于,大于等于,小于,小于等于
= 等于,NULL不安全,例如NULL = NULL的结果是NULL
<=> 等于,NULL安全,例如NULL<=>NULL的结果是TRUE(1)
!=,<> 不等于,NULL不安全
BETWEEN a0 AND a1 范围匹配,[a0, a1],如果 a0 <= value <= a1,返回 TRUE(1)
IN (option, …) 如果是option中的任意一个,返回TRUE(1)
IS NULL 是NULL
IS NOT NULL 不是NULL
LIKE 模糊匹配。% 表示任意多个(包括 0 个)任意字符;_ 表示任意一个字符

逻辑运算符:

运算符 说明
AND 多个条件必须都为TRUE(1),结果才是TRUE(1)
OR 任意一个条件为TRUE(1),结果为TRUE(1)
NOT 条件为TRUE(1),结果为FALSE(0)
  • NULL不能参与等号的比较

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

英语不及格的同学及英语成绩 ( < 60 )

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

select后面跟的表示显示哪些列,不带名称则会显示全列。where后面的语句表示进行行筛选。

语文成绩在 [80, 90] 分的同学及语文成绩

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

  • 也可以使用between…and…语句:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

数学成绩是 58 或者 59 或者 98 或者 99 分的同学及数学成绩

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

  • 或者优雅的写法:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

姓孙的同学 及 孙某同学
  • 模糊查询:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

语文成绩好于英语成绩的同学

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

总分在 200 分以下的同学

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

  • 我们尝试使用别名的方法:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

发现报错,所以我们要讨论一下sql语句的执行顺序:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

同时不能在筛选条件(where)里面做重命名!!!因为重命名都是最后一步

  • 所以只能这么做:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

语文成绩 > 80 并且不姓孙的同学

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

孙某同学,否则要求总成绩 > 200 并且 语文成绩 < 数学成绩 并且 英语成绩 > 80

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

NULL 的查询
  • 创建一张表:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

  • 进行查找:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

结果排序

语法:

– ASC 为升序(从小到大)

– DESC 为降序(从大到小)

– 默认为 ASC

注意:没有 ORDER BY 子句的查询,返回的顺序是未定义的,永远不要依赖这个顺序

  • 升序排序:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

  • 降序排序:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

  • null值一般最小(与数据库类型有关)

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

查询同学各门成绩,依次按 数学降序,英语升序,语文升序的方式显示

– 多字段排序,排序优先级随书写顺序

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

由于默认排升序:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

所以我们还可以这样写:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

查询同学及总分,由高到低

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

因为要排序所以先要有合适的数据,所以这里order by后面可以跟别名

查询姓孙的同学或者姓曹的同学数学成绩,结果按数学成绩由高到低显示

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

筛选分页结果

语法:

– 起始下标为 0
– 从 0 行开始,筛选 n 条结果

SELECT … FROM table_name [WHERE …] [ORDER BY …] LIMIT n;

– 从 s 行开始,筛选 n 条结果
SELECT … FROM table_name [WHERE …] [ORDER BY …] LIMIT s, n;

– 从 s 行开始,筛选 n 条结果,比第二种用法更明确,建议使用

SELECT … FROM table_name [WHERE …] [ORDER BY …] LIMIT n OFFSET s;

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

  • 第一种:
  • 从表头开始连续读取三行:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

  • 第二种

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

  • 第三种:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

建议:对未知表进行查询时,最好加一条 LIMIT 1,避免因为表中数据过大,查询全表数据导致数据库卡死

按id进行分页,每页3条记录,分别显示第1、2、3页

  • 实现分页功能:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

  • 通过分页能实现类似的这种成绩分组的功能:

【MySQL】基本查询(1),MySQL,mysql,数据库,linux

只有数据准备好了,才要进行显示,limit的功能本质是“显示”,所以语句执行的顺序较靠后文章来源地址https://www.toymoban.com/news/detail-852793.html

到了这里,关于【MySQL】基本查询(1)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MySQL数据库实验三 MySQL查询

    一、实验项目: MySQL查询。 二、实验目的 掌握MySQL的查询操作。 三、实验内容 (一): 1、查询lineitem表中商品编号(productid)和单价(unitprice),要求消除重复行。 2、计算lineitem表中每条记录的商品金额。 3、显示orders表单笔高于200元的客户号(userid)、成交金额(total

    2024年02月11日
    浏览(56)
  • MySQL数据库基础之MySQL查询基础

    从今天开始,本系列内容就带各位小伙伴学习数据库技术 。数据库技术是Java开发中必不可少的一部分知识内容。也是非常重要的技术。本系列教程由浅入深, 全面讲解数据库体系。 非常适合零基础的小伙伴来学习。 全文大约【 1212】 字,不说废话,只讲可以让你学到技术、

    2024年02月06日
    浏览(55)
  • MySQL数据库——MySQL SELECT:数据表查询语句

    在 MySQL 中,可以使用 SELECT 语句来查询数据。查询数据是指从数据库中根据需求,使用不同的查询方式来获取不同的数据,是使用频率最高、最重要的操作。 SELECT 的语法格式如下: 其中,各条子句的含义如下: {*|字段列名} 包含星号通配符的字段列表,表示所要查询字段的

    2024年02月05日
    浏览(80)
  • MySQL数据库,联合查询

    目录 1. 联合查询 1.1 内查询 1.2 外查询 1.3 自连接 1.4 子查询 1.5 合并查询 联合查询,简单的来讲就是多个表联合起来进行查询。这样的查询在我们实际的开发中会用到很多,因此会用 笛卡尔积 的概念。 啥是笛卡尔积?两张表经过笛卡尔积后得到的新表的列数是两表列数之和

    2023年04月23日
    浏览(76)
  • MySQL数据库,聚合查询

    目录 1、聚合查询 1.1聚合函数 1.1.1count函数 1.1.2sum函数 1.1.3avg函数 1.1.4max函数 1.1.5min函数 1.2group by子句 1.3having 聚合函数查询又叫函数查询,它是通过一些特定的函数根据需求来查询相关的信息,常见的聚合函数为: COUNT - 求总数,不包含某字段为null值 SUM - 求和,不包含某字

    2023年04月21日
    浏览(58)
  • 如何查看其他电脑的MYSQL数据库 mysql查询另一个ip数据库

    文章标签 如何查看其他电脑的MYSQL数据库mysql数据库服务器MySQL 文章分类 MySQL数据库 阅读数 143 1.如何通过IP访问MySQL数据库 1.1 改表法 1.2 授权法 2.MySQL数据库基本命令 2.1 基本命令 2.2 注释 2.3 2.4 实践操作 3 小结 1.1 改表法 如果不从远程登陆,可以用 localhost 。这个时候

    2024年01月21日
    浏览(71)
  • 数据库系统原理及MySQL应用教程实验四MySQL数据库表数据的查询操作

    1.掌握SELECT 语句的基本语法格式。 2.掌握SELECT 语句的执行方法。 3.掌握SELECT 语句的 GROUP BY 和 ORDER BY 子句的作用。 验证性实验:在公司的部门员工管理数据库的bumen表和yuangong表上进行信息查询。 设计性试验:将在student表和score表上进行查询。 ( 一 ) 验证性实验 在

    2024年02月05日
    浏览(57)
  • 【MySql】数据库的聚合查询

    写在最前面的话         哈喽,宝子们,今天给大家带来的是MySql数据库的聚合查询。在前面CRUD章节我们学习了表达式查询,表达式查询是针对列和列之间进行运算的,那么如果想在行和行之间进行运算,那么就需要用到聚合查询。 聚合查询除了包含聚合函数外(count,

    2024年02月09日
    浏览(58)
  • MySQL数据库高级查询语句

    基于这两个数据库表格来实现以下实验 concat(x,y)将提供的参数x和y拼接成一个字符串 trim()返回去除指定格式的值 GROUP BY 有一个原则,凡是在 GROUP BY 后面出现的字段,必须在 SELECT 后面出现; 凡是在 SELECT 后面出现的、且未在聚合函数中出现的字段,必须出现在 GROUP BY 后

    2024年02月11日
    浏览(70)
  • MySQL数据库——高级查询语句

    数据库是用来存储数据,更新,查询数据的工具,而查询数据是一个数据库最为核心的功能,数据库是用来承载信息,而信息是用来分析和查看的。所以掌握更为精细化的查询方式是很有必要的。本文将围绕数据的高级查询语句展开。 1.指定指字段进行查询——SELECT 语法:

    2024年02月11日
    浏览(94)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包