• PostgreSQL 正则表达式匹配字段


    在 PostgreSQL 数据库中,可以使用 ~ 和 !~ 操作符进行正则表达式的匹配和否定匹配。还可以使用 :: 操作符进行正则表达式的模式匹配。
    例如,假设我们有一个名为 users 的表,其中有一个名为 email 的字段,我们可以使用以下 SQL 语句来查找所有以 "example.com" 结尾的电子邮件地址:

    SELECT * FROM users WHERE email ~ '^[^@]+@[^@]+\.[^@]+$';  

    如果您想查找不符合上述模式的电子邮件地址,可以使用 !~ 操作符:

    SELECT * FROM users WHERE email !~ '^[^@]+@[^@]+\.[^@]+$';  

    如果您想查找所有以 "example.com" 结尾的电子邮件地址,但不包括以 "example1.com" 结尾的电子邮件地址,可以使用 :: 操作符:

    SELECT * FROM users WHERE email::'^[^@]+@[^@]+\.[^@]+$'::'^[^@]+@[^@]+\.[^@]+$' = 'example1.com';  

    请注意,上述示例中的正则表达式可能会匹配到其他类型的电子邮件地址,因此请根据实际需求进行调整。
    此外,PostgreSQL 还支持使用 regexp 函数进行正则表达式的匹配。例如,我们可以使用以下 SQL 语句来查找所有以 "example.com" 结尾的电子邮件地址:

    SELECT * FROM users WHERE email ~ '^[^@]+@[^@]+\.[^@]+$';  

    请注意,与 MySQL 不同,PostgreSQL 中的 regexp 函数不支持在 SQL 语句中直接使用。您需要将正则表达式编译成函数参数,或者将正则表达式编译成 ~ 或 !~ 操作符。

    如果是MySQL数据库,在SQL语句中进行正则表达式匹配使用REGEXP关键字

    1. select project_code,length(project_code) from test_conclusion_main
    2. where
    3. project_code REGEXP '^[a-zA-Z]{6}[0-9]{7}$'
    4. or
    5. project_code REGEXP '^[a-zA-Z]{6}[0-9]{7}V[0-9]{2}$';


    请查阅 PostgreSQL 文档以获取更多关于正则表达式的信息:https://www.postgresql.org/docs/current/functions-text.html

  • 相关阅读:
    【案例】星环科技×某能源企业:数据中台实践
    kubernetes之镜像拉取策略ImagePullSecrets;
    OpenCV4经典案例实战教程 笔记
    关于循环浅析
    Java中的static
    基于莱维飞行扰动策略的麻雀搜索算法(ISSA)(Matlab代码实现)
    漏洞复现----43、Spring Cloud Function SpEL 代码注入 (CVE-2022-22963)
    定制ASP.NET 6.0的应用配置
    想看Vue文档,cn放错位置,误入xx网站...
    一键自动化博客发布工具,用过的人都说好(cnblogs篇)
  • 原文地址:https://blog.csdn.net/LG_15011399296/article/details/133906767