SQL之最佳入门sql查询_sql查询技巧
ztj100 2025-09-04 22:14 12 浏览 0 评论
一 说明
如果是初学者,建议去网上寻找安装Mysql的文章安装,以及使用navicat连接数据库,以后的示例基本是使用mysql数据库管理系统;
二 准备前提
需要建立一张学生表,列分别是id,名称,年龄,学生信息;本示例中文章篇幅原因SQL注释略;
建表语句:
CREATE TABLE `student` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(255) DEFAULT NULL,
`age` int(11) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
三 基本检索表中的数据:
INSERT INTO `springboot`.`student`(`id`, `name`, `age`, `info`) VALUES (1, 'youku1', 18, '大一新生');
INSERT INTO `springboot`.`student`(`id`, `name`, `age`, `info`) VALUES (2, 'youku2', 23, '毕业生');
INSERT INTO `springboot`.`student`(`id`, `name`, `age`, `info`) VALUES (3, 'jeff', 25, '社会人士');
INSERT INTO `springboot`.`student`(`id`, `name`, `age`, `info`) VALUES (4, 'smile', 17, '高三学子');
三 基本检索
3.1 select 关键字
sql 都是由许多关键字(keyword)组成的语句,关键字是数据库的保留字,用户不能将其当作建表的表名,字段等;表中的数据检索使用select关键字作为开头进行查询数据库表的信息;
3.2 检索单个字段
语句示例:
SELECT name FROM student
查询结果:
youku1
youku2
jeff
smile
语句分析:
select 是 查询 的意思 , name 代表表中的字段 ,from 表示来自哪张表,其后面的student就是表;连起来的意思就是查询字段是name的数据来自表student;
3.3 sql语句注意点
多sql语句一起执行使用封号(;)隔开,在拼写语句时表的关键字都建议使用大写,表的字段和表名使用小写;为了容易阅读建议将sql分成多行(由于文章篇幅原因就不分了);sql语言也是使用英文字母,不要开中文,以免造成符号错误不容易发现;sql语句默认不区分大小写;
3.4 检索多个字段
语句示例:
SELECT name,age FROM student;
语句结果:
youku1 18
youku2 23
jeff 25
smile 17
语句分析:
查询字段 名字,年龄来自表student;多个列检索时使用逗号(,)隔开;
3.5 检索所有字段
语句示例:
SELECT * FROM student;
语句结果:
1 youku1 18 大一新生
2 youku2 23 毕业生
3 jeff 25 社会人士
4 smile 17 高三学子
语句分析:
通配符 (*)表示返回表中的所有列,如果不是必须建议不要使用通配符,会影响数据库性能;
3.6 distinct
distinct 表示区分,意指检索出来的行是唯一(去重),其放在列的最前面;如果使用了关键字distinct,其作用于后面的所有列(由于本示例数据没有重复示例,结果就不是很清晰);
SELECT DISTINCT name, age FROM student;
语句结果:
youku1 18
youku2 23
jeff 25
smile 17
3.7 限制条数
access 和 sql server :
SELECT TOP 2 name FROM student
TOP 2 表示限制返回前2行
postgresql 、SQLite和 mysql:
SELECT name FROM student LIMIT 2;
limit 2 表示限制返回前2行;
DB2:
SELECT name FROM student FETCH FIRST 2 ROWS ONLY
FETCH FIRST 2 ROWS ONLY 表示只抓取前2行数据
语句结果:
youku1
youku2
3.8偏移
示例:
SELECT name FROM student LIMIT 1 OFFSET 1;
语句分析
表示查询列名称来自学生表 限制条数1,偏移值1;意思就是查询学生表中的第二行数据;offset表示跳跃或者偏移;
mysql和MariaDB简化形式:
SELECT name FROM student LIMIT 1,2;
表示查询字段名称来自学生表,限制2条,偏移1条;注意顺序;
语句结果:
youku2
jeff
四 排序检索
4.1 ORDER BY 子句
示例:
SELECT name,age FROM student ORDER BY age
语句分析;
检索字段名称,年龄来自学生表按照列年龄排序;注意默认是升序,ORDER BY 子句通常在语句末尾;
语句结果:
smile 17
youku1 18
youku2 23
jeff 25
4.2 多列排序
示例:
SELECT name,age FROM student ORDER BY age DESC, name ASC;
语句分析:
查询名称,年龄来自学生表,按照年龄降序,名称升序进行排序;关键字 DESC(descending) 意指降序,字母默认Z-A; ASC(ascending)意指升序,字母默认A-Z;多列情况下,每个列后面指定使用DESC,使用逗号(,)隔开,如果不写,默认升序;
语句结果:
jeff 25
youku2 23
youku1 18
smile 17
4.3 按位排序
语句示例:
SELECT name,age FROM student ORDER BY 2 DESC, 1 ASC;
按位指查询字段的位置,2 对应字段age,1对应字段name;结果和4.2一致;
五 过滤检索
sql 语句中过滤条件(filter condition)的关键字是 WHERE,其使用方式是跟在表名之后;
5.1 WHERE语句操作符
根据不同的数据库管理系统,其支持的操作符略有不同,所以下文较多重复意思的操作符,应查阅官方文档说明,哪些操作符是支持使用的数据库管理系统;
5.2 单条件过滤
示例:
SELECT * FROM student WHERE name = 'jeff';
语句分析;
查询所有字段来自学生表 条件是 学生名称是 jeff;注意 非表字段,表名,关键字,使用2个单引号(’’)括起来,里面存放的是我们输入的数据;
语句结果;
3 jeff 25 社会人士
5.3 多条件过滤
多条件过滤时使用 AND 或者 OR 子句;AND连接表达式表示过滤条件都为真的数据;OR连接表达式表示匹配过滤条件任意一个;
AND示例:
SELECT * FROM student WHERE age >= '18' AND age <= '23';
语句分析:
查询所有字段来自学生表,条件是 学生年龄大于等于18 并且 学生年龄小于 23;
语句结果:
1 youku1 18 大一新生
2 youku2 23 毕业生
OR示例:
SELECT * FROM student WHERE age >= '18' OR age <= '23';
语句分析:
检索所有字段来自学生表,条件是 学生年龄大于等于18,或者学生年龄小于23;
OR 和 AND 示例:
SELECT * FROM student WHERE age >= '18' AND (age <= '23' OR id >=2);
语句分析:
在使用OR 和 AND 的时候应该明确过滤条件,然后使用小括号括起来,由于数据库管理系统是根据顺序执行,如果不使用小括号很容易造成语义错误;查询所有字段来自学生表 过滤条件 年龄大于 18 并且 (年龄小于23 或者 id 大于2)的数据;
5.4 范围查询
示例:
SELECT * FROM student WHERE age BETWEEN '18' And '23';
语句分析
BETWEEN 表示范围查询,查询所有字段来自学生表,过滤条件学生年龄在18至23之间;
语句结果:
1 youku1 18 大一新生
2 youku2 23 毕业生
5.5 空值查询
示例:
SELECT * FROM student WHERE age IS NULL;
语句分析:
查询所有字段来自学生表,过滤条件 学生年龄 为空;数据库表不填充数据默认为空(NULL),当然你也可以给指定类型的列设置默认值;
5.6 IN 操作
示例:
SELECT * FROM student WHERE age IN (18,23,25);
语句分析:
查询所有字段来自学生表 ,过滤条件 年龄 是 18 或者 23 或者 25 ;IN是个范围查询,匹配小括号中指定的任意值,其功能跟OR类似,一个IN 就相当于好多个OR;
语句结果:
1 youku1 18 大一新生
2 youku2 23 毕业生
3 jeff 25 社会人士
5.7 NOT 操作符
示例:
SELECT * FROM student WHERE NOT age='25';
语句分析:
NOT 操作符表是否定;其跟在WHERE后面功能类似<>;
六 通配符检索
6.1 通配符的介绍
通配符是组成匹配模式的特殊字符串;如果有用过正则表达式的同学肯定不陌生,这个与其类似;检索文本的通配符是用在关键词Like 后面;
6.2 通配符 %
示例:
SELECT * FROM student WHERE name LIKE 'you%' ;
语句分析:
查询所有字段来自学生表,过滤条件 名字匹配以you开头的字符串后面匹配任意个任意字符;%通配符代表任意个任意字符串,0也算在内,但不包括null;
语句结果:
1 youku1 18 大一新生
2 youku2 23 毕业生
示例:
SELECT * FROM student WHERE name LIKE '%i%' ;
语句分析:
查询所有列来自学生表,过滤条件学生的名称匹配中间必须出现一次字母i,字母i的前后可以匹配任意个任意字符串;
语句结果;
4 smile 17 高三学子
6.3 通配符 _
通配符 _ 代表匹配一个字符串;在Access数据库中不是 _ 而是 ?;
示例:
SELECT * FROM student WHERE name LIKE 'youku_' ;
语句分析:
查询所有列来自学生表,过滤条件 学生名称 匹配模式 youku 后面一个为任意字符串;
语句结果;
1 youku1 18 大一新生
2 youku2 23 毕业生
6.4 通配符 []
通配符 [] 表示匹配指定一个位置一个字符;其里面可以存放多个字符,关系是or,模式匹配时只占用一个位置,Access,SQL SERVER 支持;
七 字段基本操作
7.1 字段拼接
示例:
SELECT concat('你好啊',name,'327今天心情怎么样') FROM student WHERE id = '1' ;
语句分析:
函数 concat 就是将多个字符子串拼接成一个字符串;不同的数据库管理系统其使用的方式略有差别,应查阅官方文档;
在 mysql 中使用 concat函数;在postgresql中使用 || ; 在 Access和 sql server中使用 +;
语句结果:
你好啊youku1327今天心情怎么样
7.2 去除空白字符串
语句示例:
SELECT RTRIM(' 哥,今天管饱 ') FROM student WHERE id = '1' ;
语句分析:
RTRIM(STR) 函数是去掉右边的字符串;TRIM(STR)是去掉字符串两边的空白字符;LTRIM(STR)是去掉字符串左边的空白字符;
语句结果;
哥,今天管饱
7.3 别名
语句示例:
SELECT name as student_name FROM student WHERE id = '1' ;
语句分析:
别名(alias)是可以给字段,或者表起别名;当多表操作出现重复字段时使用别名是个很好的选择;别名可以使用AS关键字,虽然其是可省略,但平时我们最好加上它增强阅读性;
7.4 计算
语句示例:
SELECT 2 * 8;
语句结果:
16
相关推荐
- sharding-jdbc实现`分库分表`与`读写分离`
-
一、前言本文将基于以下环境整合...
- 三分钟了解mysql中主键、外键、非空、唯一、默认约束是什么
-
在数据库中,数据表是数据库中最重要、最基本的操作对象,是数据存储的基本单位。数据表被定义为列的集合,数据在表中是按照行和列的格式来存储的。每一行代表一条唯一的记录,每一列代表记录中的一个域。...
- MySQL8行级锁_mysql如何加行级锁
-
MySQL8行级锁版本:8.0.34基本概念...
- mysql使用小技巧_mysql使用入门
-
1、MySQL中有许多很实用的函数,好好利用它们可以省去很多时间:group_concat()将取到的值用逗号连接,可以这么用:selectgroup_concat(distinctid)fr...
- MySQL/MariaDB中如何支持全部的Unicode?
-
永远不要在MySQL中使用utf8,并且始终使用utf8mb4。utf8mb4介绍MySQL/MariaDB中,utf8字符集并不是对Unicode的真正实现,即不是真正的UTF-8编码,因...
- 聊聊 MySQL Server 可执行注释,你懂了吗?
-
前言MySQLServer当前支持如下3种注释风格:...
- MySQL系列-源码编译安装(v5.7.34)
-
一、系统环境要求...
- MySQL的锁就锁住我啦!与腾讯大佬的技术交谈,是我小看它了
-
对酒当歌,人生几何!朝朝暮暮,唯有己脱。苦苦寻觅找工作之间,殊不知今日之事乃我心之痛,难道是我不配拥有工作嘛。自面试后他所谓的等待都过去一段时日,可惜在下京东上的小金库都要见低啦。每每想到不由心中一...
- MySQL字符问题_mysql中字符串的位置
-
中文写入乱码问题:我输入的中文编码是urf8的,建的库是urf8的,但是插入mysql总是乱码,一堆"???????????????????????"我用的是ibatis,终于找到原因了,我是这么解决...
- 深圳尚学堂:mysql基本sql语句大全(三)
-
数据开发-经典1.按姓氏笔画排序:Select*FromTableNameOrderByCustomerNameCollateChinese_PRC_Stroke_ci_as//从少...
- MySQL进行行级锁的?一会next-key锁,一会间隙锁,一会记录锁?
-
大家好,是不是很多人都对MySQL加行级锁的规则搞的迷迷糊糊,一会是next-key锁,一会是间隙锁,一会又是记录锁。坦白说,确实还挺复杂的,但是好在我找点了点规律,也知道如何如何用命令分析加...
- 一文讲清怎么利用Python Django实现Excel数据表的导入导出功能
-
摘要:Python作为一门简单易学且功能强大的编程语言,广受程序员、数据分析师和AI工程师的青睐。本文系统讲解了如何使用Python的Django框架结合openpyxl库实现Excel...
- 用DataX实现两个MySQL实例间的数据同步
-
DataXDataX使用Java实现。如果可以实现数据库实例之间准实时的...
- MySQL数据库知识_mysql数据库基础知识
-
MySQL是一种关系型数据库管理系统;那废话不多说,直接上自己以前学习整理文档:查看数据库命令:(1).查看存储过程状态:showprocedurestatus;(2).显示系统变量:show...
- 如何为MySQL中的JSON字段设置索引
-
背景MySQL在2015年中发布的5.7.8版本中首次引入了JSON数据类型。自此,它成了一种逃离严格列定义的方式,可以存储各种形状和大小的JSON文档,例如审计日志、配置信息、第三方数据包、用户自定...
你 发表评论:
欢迎- 一周热门
-
-
MySQL中这14个小玩意,让人眼前一亮!
-
旗舰机新标杆 OPPO Find X2系列正式发布 售价5499元起
-
【VueTorrent】一款吊炸天的qBittorrent主题,人人都可用
-
面试官:使用int类型做加减操作,是线程安全吗
-
C++编程知识:ToString()字符串转换你用正确了吗?
-
【Spring Boot】WebSocket 的 6 种集成方式
-
PyTorch 深度学习实战(26):多目标强化学习Multi-Objective RL
-
pytorch中的 scatter_()函数使用和详解
-
与 Java 17 相比,Java 21 究竟有多快?
-
基于TensorRT_LLM的大模型推理加速与OpenAI兼容服务优化
-
- 最近发表
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)
- vmware17pro最新密钥 (34)
- mysql单表最大数据量 (35)