百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

SQL知识大全三):SQL中的字符串处理和条件查询

mhr18 2024-10-13 03:04 36 浏览 0 评论


点击上方蓝字关注我们


今天是SQL系列的第三讲,我们会讲解条件查询,文本处理,百分比,行数限制,格式化以及子查询。


条件查询


IF条件查询

#if的语法
IF(expr1,expr2,expr3)
#示例
SELECT IF(sva=1,"男","女") AS s FROM table_name 
WHERE sva != '';?

CASE WHEN条件查询

case when 可以实现if函数的功能,同时也可以联合各类聚合函数使用。

# case when也可以实和if一样的功能
?SELECT CASE 
WHEN sva=1 THEN '男' 
  ELSE '女' 
END AS s 
FROM table_name
WHERE sva != '';


#case when可以联合聚合函数等使用
?SELECT count(DISTINCT CASE
                          WHEN sva=1 THEN 'id'
                          ELSE 'null'
                      END) AS s
FROM TABLE_NAME
WHERE sva != '';


文本处理


SUBSTR()字符串截取

substr语法详解:

substr(strings|express,m,[n])

strings|express :被截取的字符串或字符串表达式

m 从第m个字符开始截取

n 截取后字符串长度为n

示例:
  select substr('abcdefg',3,4) from dual;
  # 结果是cdef


  select substr('abcdefg',-3,4) from dual;
  # 结果efg
  
  select substr('abcde',2),substr('abcde',-2),substr('abcde',2,3),substr('abcdewww',-7,3) from dual;
  # 结果是bcde、de、bcd、bcd


字符串拼接

1.使用特殊操作符拼接

#ACESS和SQL Serve使用+
SELECT vend_name + ' (' + vend_country + ')'
FROM Vendors
ORDER BY vend_name;


#DB2,Oracle, PostgreSQL,SQLite ,Open Office Base使用||
SELECT vend_name || ' (' || vend_country || ')' 
FROM Vendors
ORDER BY vend_name;

2.CONCAT()函数拼接

SELECT Concat(vend_name, ' (', vend_country, ')') 
FROM Vendors
ORDER BY vend_name; 


SPLIT()字符串分割

语法结构

split(str, regex) - Splits

str:需要分割的字符

regex:以什么符号进行分割

1.基本用法

split('a,b,c,d',',')
# 得到的结果:
["a","b","c","d"]

2.截取字符串中的某个值

当然,我们也可以指定取结果数组中的某一项

split('a,b,c,d',',')[0]


# 得到的结果:
a

3.特殊字符的处理

特殊分割符号

regex 为字符串匹配的参数,所以遇到特殊字符的时候需要做特殊的处理

# 例3: "." 点
split('192.168.0.1','.')


# 得到的结果:
[]
# 正确的写法:
split('192.168.0.1','\\.')
# 得到的结果:
["192","168","0","1"]


LENGTH()返回字符串长度

SELECT length(vend_name) vend_len
FROM Vendors
ORDER BY vend_name;


LOWER()/UPPER()将字符串转换为小写或大写

SELECT vend_name, 
LOWER(vend_name) AS vend_name_lowcase,
UPPER(vend_name) AS vend_name_upercase 
FROM Vendors
ORDER BY vend_name;

REPLACE()字符串替换

#将adress字段中的区替换为”呕“
select *,replace(address,'区','呕') AS rep
from test_tb


LEFT()/RIGHT()返回字符串左边或右边的字符

select left(CONTRACT_NAME,2)
from
gb_t_contract 
where 1=1;
#从字符表达式最左边一个字符开始返回指定数目的字符.
#若 b 的值大于 a 的长度,则返回字符表达式的全部字符a.如果 b 为负值或 0,则返回空字符串.




select left('2323232',9) ;
# 返回值为空


LTRIM()/RTRIM()/TRIM()去掉字符串左边/右边或全部空格

select ltrim('   sample ') from table;
# 返回结果:'sample '
select rtrim('   sample ') from table;
# 返回结果:'   sample'
select trim('   sample ') from table;


# 返回结果:'sample'

SOUNDEX() 返回字符串SOUNDEX值

#近似匹配
SELECT cust_name, cust_contact
 FROM Customers
 WHERE SOUNDEX(cust_contact) = SOUNDEX('Michael Green');

CAST数据类型转换

# 将str类型的dt字段转换为int类型的
select cast(dt as int)  dt
from table


取百分比


percentile()

语法格式:

percentile_approx(DOUBLE col, p ,[B])) 近似中位数函数

percentile(DOUBLE col, p ) 中位函数


前者多了一个参数B,后者无参数,其余语法一致。

求近似的第pth个百分位数,p必须介于0和1之间,返回类型为double,但是col字段支持浮点类型。参数B控制内存消耗的近似精度,B越大,结果的准确度越高。默认为10,000。当col字段中的distinct值的个数小于B时,结果为准确的百分位数。

select percentile(mmr,0.3) as 30_percentile,
percentile_approx(mmr,0.5) 50_percentile
from match_table


限制行数


LIMIT的用法

select account_id,account_name
from table
limt 100


格式化显示


FORMAT()数据格式化

FORMAT() 函数用于对字段的显示进行格式化。

SQL FORMAT() 语法:

SELECT FORMAT(column_name,format) FROM table_name;


FORMAT(X,D):强制保留D位小数,整数部分超过三位的时候以逗号分割,并且返回的结果是string类型的。


 SELECT FORMAT(100.3465,2),FORMAT(100,2),FORMAT(,100.6,2);
 # 结果分别:100.35,100.00,100.60


子查询


1.子查询条件过滤

SELECT cust_id
FROM Orders
WHERE order_num IN (SELECT order_num
FROM OrderItems
WHERE prod_id = 'RGAN01');

2.子查询作为计算字段


SELECT cust_name,
       cust_state,
       (SELECT COUNT(*)
         FROM Orders
         WHERE Orders.cust_id = Customers.cust_id) AS orders 
FROM Customers
ORDER BY cust_name;



参考书籍:《SQL必知必会》


SQL系列文章持续更新中


往期推荐

SQL知识大全(一):数据库的语言分类你都知道吗?

史上最全的SQL知识点汇总,错过这次等一年

游戏行业指标体系大全(一)

游戏行业指标体系大全(二)

数据岗知识体系及岗位介绍



分享数据知识,成就数据理想

相关推荐

说说Redis的单线程架构(redis的单线程模型)

一句话总结Redis采用单线程处理命令请求,避免了多线程的上下文切换和锁竞争,保证原子性操作。其基于内存的高效执行和I/O多路复用模型支撑了高并发性能。网络I/O和持久化操作(如RDB/AOF)由后台...

答记者问之 - Redis 的高效架构与应用模式解析

问:极客程序员你好,请帮我讲一讲redis答:redis主要涉及以下核心,我来一一揭幕Redis的高效架构与应用模式解析Redis是一个开源的内存数据存储系统,因其高性能、丰富的数据结构和易用性...

Redis的5种核心数据结构,及其最经典的“应用场景”

Redis凭什么稳坐缓存界头把交椅?全靠这五个“身怀绝技”的数据结构!在分布式系统的江湖里,Redis就像一位身怀绝技的武林高手,而它的五大核心数据结构正是克敌制胜的五套绝学。今天咱们就来拆解这些独门...

精准定位文件包含漏洞:代码审计中的实战思维

前言最近看到由有分析梦想cms的,然后也去搭建了一个环境看了一看,发现了一个文件包含漏洞的点,很有意思,下面是详细的复现和分析,以后代码审计又多了一中挖掘文件包含漏洞的新思路环境搭建下载https...

ARDM:一款国产跨平台的Redis管理工具

ARDM(AnotherRedisDesktopManager)是一款免费开源的Redis桌面管理客户端,支持Windows、Mac、Linux跨平台。功能特性ARDM提供的主要功能如...

SpringBoot的Web应用开发——Web缓存利器Redis的应用!

 Web缓存利器Redis的应用Redis是目前使用非常广泛的开源的内存数据库,是一个高性能的keyvalue数据库,它支持多种数据结构,常用做缓存、消息代理和配置中心。本节将简单介绍Redis的使...

Windows服务器部署CRMEB开源电商系统,详细教程来了!

安装PHP已经安装过PHP的可以跳过首先安装VC运行库下载地址https://docs.microsoft.com/zh-cn/cpp/windows/latest-supported-vc-redi...

Windows系统下Redis各个安装包介绍与选择指南

简介Redis作为高性能的键值数据库,广泛应用于缓存、消息队列等场景。在Windows系统中部署Redis时,用户可以选择多种安装包以满足不同的需求。本文将详细介绍以下Redis8.0.3版本的安装...

从面试题入手,深度剖析Redis Cluster原理

揭开RedisCluster的神秘面纱**在当今数字化浪潮中,数据量呈爆炸式增长,应用程序对数据存储和处理的要求也日益严苛。Redis作为一款高性能的内存数据库,凭借其出色的读写速度和丰富的数...

给大家推荐些好的c语言代码的网站

C语言,那就来推荐几个吧,部分含有C++:1、TheLinuxKernelArchives(kernel.org)Linux内核源码,仅限于C,但内核庞大,不太适合新手;2、redis(redi...

Redis String 类型的底层实现与性能优化

RedisString是Redis中最基础也是应用最广泛的数据类型,它能存储文本、数字、二进制数据等多种形式的信息。深入理解其底层实现对构建高性能分布式系统至关重要。Redis字符串的底层结...

阿里面试问:Redis 为什么把简单的字符串设计成 SDS?

分享了一道面阿里的redis题,我看了以后觉得挺有意思。题目大致是这样的面试官:了解redis的String数据结构底层实现嘛?铁子:当然知道,是基于SDS实现的面试官:redis是用C语言开发的,那...

编程语言那么多,为何C语言能成为最成功的语言?

编程语言那么多,为何C语言能成为最成功的语言?2025年嵌入式岗位暴增47%,新人却还在问"C语言过时了吗"。真相是连机器人关节驱动都得靠它写,不会指针连芯片手册都看不懂。见过用Pyt...

go-zero 使用 redis 作为 cache 的 2 种姿势

在go-zero框架内,如在rpc的应用service中,其内部已经预置了redis的应用,所以我们只需要在配置中加入相关字段即可,另外,在svcContext声明redisc...

Redis事务深度解析:ACID特性、执行机制与生产实践指南

一、Redis事务的本质与核心机制Redis事务通过MULTI、EXEC、WATCH等命令实现,其本质是将多个命令序列化后一次性执行,而非传统数据库的严格事务模型。核心特点如下:命令队列化:MULT...

取消回复欢迎 发表评论: