正则表达式与SQL数据库教程

使用正则表达式通过用例查询 Postgres 数据库:

正则表达式(又名 Regex)

  • 正则表达式是一个强大的工具,广泛用于模式匹配和文本操作。

  • 几乎所有编程语言都支持它们,并且经常用于文本提取、搜索和匹配文本等用例。

  • 正则表达式匹配以"^"字符开头,以"$"字符结尾。

例子

  • 假设我们要验证给定的字符串是否是有效的 Visa 信用卡号。

  • 输入字符串为"4111111111111111"。

  • 我们的正则表达式为:"40--9{12}(?:0--9{3})?" 40--9{12}:正则表达式的这一部分基本上表示该模式以 4 开头,后跟包含 (0--9) 的 12 个数字。现在总共有 13 位数字。(?:0--9{3}):旧的 Visa 卡有 13 位数字,因此这代表可选的 3 位数字。

现在基础知识已经清楚了,让我们讨论如何使用正则表达式进行数据库查询。

正则表达式与数据库

  • 使用正则表达式可以使 SQL 查询动态化并提高性能。

  • 在本文中,我们将使用支持正则表达式的 Postgres 数据库。

我们需要记住,并非所有数据库都支持正则表达式。

Postgres

  • 我们可以使用 ~(TILDE) 运算符和 .*(通配符运算符)来实现 PostgreSQL 中的正则表达式。

列表

~:用于匹配正则表达式的字符串,区分大小写

搜索所有符合模式的电子邮件

postgres=# select email from accounts where email ~ '^\S+@\S+\.\S+$';

  1. !~:用于字符串,不匹配正则表达式,区分大小写。

搜索所有与模式不匹配的电子邮件

postgres=# select email from accounts where email !~ '^\S+@\S+\.\S+$';

  1. ~*:用于字符串匹配正则表达式,不区分大小写。

s以不区分大小写的方式搜索与模式匹配的所有电子邮件

postgres=# select email from accounts where email !~ '^\S+@\S+\.\S+$';

  1. !~*:用于不匹配正则表达式的字符串,不区分大小写。

搜索所有与模式不匹配的邮件,不区分大小写

postgres=# select email from accounts where email !~ '^\S+@\S+\.\S+$';

用例:通过品牌名称查找信用卡

  • 我们的输入表是credit_card,其中包含卡号和到期日期。

表中记录:

postgres=# select * from credit_card;

id | card_number | expiry_date | customer_id

----+------------------+-------------+-------------

11 | 2344323432112222 | 2023-04-10 | 10

10 | 2344323432112422 | 2023-04-12 | 10

13 | 4111111111111111 | 2023-04-11 | 10

14 | 4111111131111111 | 2023-05-11 | 10

15 | 4111111131119111 | 2023-05-12 | 10

17 | 378282246310005 | 2023-05-09 | 10

18 | 378282246710005 | 2024-05-09 | 10

21 | 4111111131119 | 2025-05-12 | 10

(8 rows)

查询Visa信用卡

postgres=# select * from credit_card where card_number ~ '^40-9{12}(?:0-9{3})?$';

  • Visa信用卡均以4开头,旧卡为13位,新卡为16位。
  • 我们的查询返回预期的 4 张以 4 开头的卡片。

美国运通:

postgres=# select * from credit_card where card_number ~ '^3470-9{13}$';

  • 所有Amex信用卡均以3开头,第二位数字为4或7。总数字为15。
  • 我们的查询返回预期的 3 个结果。

用例:查找所有与 emailId 模式不匹配的电子邮件

在正则表达式中,我们正在寻找characters@characters.character(例如abc@gmail.com)模式。

我们正在过滤所有不符合模式的电子邮件的查询。

select email from accounts where email !~ '^\S+@\S+\.\S+$';

我们的输出包含不具有上述定义模式的电子邮件。

postgres=# select email from accounts where email !~ '^\S+@\S+\.\S+$';

email


abctest.com

(1 row)

https://www.jdon.com/70336.html

相关推荐
山河木马10 小时前
渲染管线-计算得到gl_Position(顶点着色器)之后续GPU流程
javascript·webgl·图形学
竹林81810 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
kyriewen13 小时前
别再每次都 Google 了:我整理了前端日常最常踩的 10 个 Git 坑,附速查表
前端·javascript·git
SmartBoyW14 小时前
深入ECMAScript规范:彻底搞懂JS隐式类型转换与底层ToPrimitive机制
前端·javascript
用户8524950718415 小时前
解密 JavaScript 中的 this:谁才是真正的调用者?
javascript·面试
Heo15 小时前
Vite进阶用法详解
前端·javascript·面试
铁皮饭盒16 小时前
Next.js 风格路由内置?Bun FileSystemRouter 凭啥这么香
javascript
小林ixn17 小时前
别再背八股了!从 5 个真实场景彻底搞懂 JavaScript 的 this
javascript
东风破_18 小时前
JavaScript 面试常考的字符串算法:从反转字符串到回文判断
前端·javascript
巴勒个啦18 小时前
D3.js 入门实战:用力导向图可视化项目依赖关系
javascript