限制数据库字段长度的公用写法:length和like和rlike对于限制字段长度的原理与区别

关于数据库字段长度的探索:

  • length和like和rlike对于限制字段长度的原理与区别
    • length
    • like、rlike
      • ==like的_下划线通配符==
      • ==rlike的正则表达式==
      • ==regexp、regexp_like的正则表达式==


length和like和rlike对于限制字段长度的原理与区别

探索之前先简单介绍下:
length函数可以返回每条数据的字段的长度,like和rlike一般用作模糊匹配关键字查询


length

length返回字段长度的原理是与每个数据库对于字符编码方式的设计挂钩的,计算的是字节,一般都是utf8,这样数据库里一个中文或者一个中文符号就占用3个字节,其他的英文、数字、英文符号、空格就只占用1个字节。
在这里插入图片描述
在这里插入图片描述
这样的话和我们想的就不一样,我们想的就是不管是中文英文数字还是符合就是长度为1个。在mysql里就有char_length这个函数实现这个功能。
在这里插入图片描述
但在oracle里length一个中文就是返回1。对于这种length函数不通用与大部分数据库的标准写法时,我们就可以间接使用模糊查询来避免换数据库后带来的长度不一致的困扰。


like、rlike

在这里我就不介绍常用的功能了,就只针对限制字段长度,不管是中文、英文、数字、还是符号,来介绍一个公用的写法:

like的_下划线通配符

我们知道like有下划线的通配符,一个下划线表示任意一个字符。
如下表里,姓名字段里一个两个三个四个五个字符的都有。
在这里插入图片描述


/**这里like了两个下划线就表示姓名只有两个任意的字符**/SELECT * FROM 学生基本信息
WHERE STUNAME LIKE '__'

在这里插入图片描述


rlike的正则表达式

据我了解like下划线的方式只能限定固定长度,比如我们想要2到4个长度的姓名时,我们就可以使用rlike:
RLIKE ‘^.{n,m}$’

RLIKE '^.{n,m}$'^表示开头    
.在rlike的正则表达里表示匹配任意字符
{n,m}的规则就是n<=m 
最后$表示结尾^.就是以任意字符开头
^.{2,4}表示以任意2到4个字符开头
不写这个$的话这个{2,4}里的4就没有意义了   就只有里面的2有意义RLIKE '^.{2,4}$' 表示字段里最少有2个最多有4个字符

在这里插入图片描述


regexp、regexp_like的正则表达式

如果数据库不支持rlike,例如oracle就不支持,就可以用regexp或者regexp_like来代替rlike

REGEXP_LIKE(字段名,'^.{n,m}$')
字段名 REGEXP '^.{n,m}$' 这两个的意思和功能和 RLIKE '^.{n,m}$' 一样

查询姓名只有一个字和两个字的数据:
在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/32411.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LabVIEW cRIO中CSV文件的读取

在LabVIEW cRIO中读取CSV文件&#xff0c;需通过文件传输、路径配置、数据解析等步骤实现。本文详细说明如何通过代码读取本地存储的CSV文件&#xff0c;并探讨直接通过对话框选择文件的可行性及替代方案。 一、CSV文件传输至cRIO本地存储 1. 使用NI MAX文件管理 步骤&#xf…

DeepSeek-R1 论文阅读总结

1. QA问答&#xff08;我的笔记&#xff09; Q1: DeepSeek如何处理可读性问题&#xff1f; 通过构建冷启动数据&#xff08;数千条长CoT数据&#xff09;微调基础模型&#xff0c;结合多阶段训练流程&#xff08;RL训练、拒绝采样生成SFT数据&#xff09;&#xff0c;并优化输…

prometheus的动态发现(基于文件和consul)

prometheus的配置参考&#xff1a;https://prometheus.io/docs/prometheus/2.53/configuration/configuration/ 没有使用动态配置前&#xff0c;需要在 prometheus.yml 这个配置文件中创建数据采集任务&#xff0c;然后重新加载服务。 如果把采集job剥离出去&#xff0c;写在…

安卓逆向魔改版 Base64 算法还原

版权归作者所有&#xff0c;如有转发&#xff0c;请注明文章出处&#xff1a;https://cyrus-studio.github.io/blog/ 目标 app 简介 可以看到 app 中共有 4 种 Base64 算法。选中一个随机字符串&#xff0c;可以选择其中一种算法进行编码解码。 app地址&#xff1a;https://gi…

CI/CD—GitLab部署

GitLab简介&#xff1a; GitLab 是一个用于代码托管和软件开发协作的平台&#xff0c;在全球开发者社区及企业中应用广泛&#xff0c;以下是对它的详细介绍&#xff1a; 主要功能 代码托管&#xff1a;提供了基于 Git 的代码仓库管理功能&#xff0c;支持创建、克隆、推送、…

采集OPCUA/S7

需求&#xff1a;采集OPCUA服务数据 采用&#xff1a;KEPServerEX6获取OPCUA服务数据 1.新建甬道3 2.驱动程序选择&#xff1a;OPC UA client 3.设置UA服务器-端点URL&#xff1a;opc.tcp://ip:502 安装教程&#xff1a;https://blog.csdn.net/weixin_41425107/article/detai…

3.12代码随想录第十五天打卡

654.最大二叉树 (1)题目描述: (2)解题思路: class Solution { public:TreeNode* constructMaximumBinaryTree(vector<int>& nums) {TreeNode* node new TreeNode(0);if (nums.size() 1) {node->val nums[0];return node;}// 找到数组中最大的值和对应的下标…

安全左移动赋能:灵脉IAST交互式应用安全测试平台

左移的安全赋能 Earlier Security Empowerment 悬镜灵脉IAST灰盒安全测试平台作为国内领先的交互式应用安全测试平台&#xff0c;透明集成于现有IT流程&#xff0c;自动化完成业务代码上线前安全测试&#xff0c;重点覆盖90%以上中高危漏洞&#xff0c;防止应用带病上线&…

Linux下学【MySQL】常用函数助你成为数据库大师~(配sql+实操图+案例巩固 通俗易懂版~)

绪论​ 每日激励&#xff1a;“唯有努力&#xff0c;才能进步” 绪论​&#xff1a; 本章是MySQL中常见的函数&#xff0c;利用好函数能很大的帮助我们提高MySQL使用效率&#xff0c;也能很好处理一些情况&#xff0c;如字符串的拼接&#xff0c;字符串的获取&#xff0c;进制…

波特率、比特率、传信率、传码率......

去年搞过一段时间的无线通信&#xff0c;当时我脑子里真的是一团乱麻&#xff0c;本身咱也不是学通信的&#xff0c;咱是学机械出身的&#xff0c;后面又搞电&#xff0c;反正对于通信这一块就不是很懂&#xff0c;后面也慢慢搞出来了一点小东西&#xff0c;但是对于一些细节还…

华为HCIE认证用处大吗?

新盟教育 专注华为认证培训十余年 为你提供认证一线资讯&#xff01; 在ICT行业的认证体系中&#xff0c;华为HCIE认证一直备受关注。那么&#xff0c;华为HCIE认证用处大吗&#xff1f;今天咱们就来深入探讨一下&#xff0c;以数据通信方向为例&#xff0c;看看它到底能带来什…

【WRF-Chem】预处理工具(Preprocessors)总结

WRF-Chem 预处理工具&#xff08;Preprocessors&#xff09; 化学选项&#xff08;Chemistry Options&#xff09;数据下载 预处理工具&#xff08;Preprocessors&#xff09;工具1&#xff1a;mozbc工具2&#xff1a;bio_emiss工具3&#xff1a;anthro_emiss工具4&#xff1a;…

六、OpenGL中EBO的使用及本质

文章目录 一、什么是顶点索引二、什么是EBO三、EBO使用的完整代码 一、什么是顶点索引 OpenGL 中&#xff0c;顶点索引&#xff08;Vertex Index&#xff09;用于减少重复的顶点数据&#xff0c;提高绘制效率。其核心概念涉及索引缓冲对象&#xff08;Index Buffer Object&…

Python+jupyter进行数据分析与数据挖掘

随着人工智能的发展&#xff0c;现在越来越多人使用Python语言进行数据分析。Python在数据分析中有哪些优势呢&#xff1f;由于Python中有很多的第三方插件&#xff0c;接下来我们探讨Pythonjupyter的结合&#xff0c;在数据分析领域中的应用。 一、jupyter介绍 Jupyter 是一个…

AI4CODE】3 Trae 锤一个贪吃蛇的小游戏

【AI4CODE】目录 【AI4CODE】1 Trae CN 锥安装配置与迁移 【AI4CODE】2 Trae 锤一个 To-Do-List 这次还是采用 HTML/CSS/JAVASCRIPT 技术栈 Trae 锤一个贪吃蛇的小游戏。 1 环境准备 创建一个 Snake 的子文件夹&#xff0c;清除以前的会话记录。 2 开始构建 2.1 输入会…

PostgreSQL17(最新版)安装部署

PostgreSQL 17已与2024年9月26日正式发布&#xff01;&#xff01;&#xff01; 一、Postgres概述 官网地址&#xff1a;PostgreSQL: The world’s most advanced open source database Postgres作为最先进的开源数据库&#xff08; the latest version of the world’s most…

捌拾贰- 贝尔不等式 (2)

1. 贝尔不等式理解 我感觉我前期理解的不是很对 柒拾玖- 贝尔不等式 … 思来想去几天&#xff0c;感觉贝尔不等式应该是这样来的 因为观测的值只有可能是 1 (别问我为什么) , 设观测角度 Q 值为 1 的概率为 a , -1 的概率为 b , Q 的数学期望值为 E(Q) a * 1 b * (-1) a…

小凯的疑惑(数论 )

#include <iostream> using namespace std; typedef long long ll; int main() {// 请在此输入您的代码ll a,b;cin>>a>>b;ll N a * b - a - b;cout << N ;return 0; } 如果 a 和 b 互素&#xff0c;那么 a * b - a - b 是最大无法被表示的金额

Android内存泄漏检测与优化

Android内存泄漏检测与优化 一、内存泄漏基础知识 1.1 什么是内存泄漏 在Android开发中&#xff0c;内存泄漏(Memory Leak)是指程序在申请内存后&#xff0c;无法释放已申请的内存空间&#xff0c;导致系统可用内存减少的问题。随着泄漏内存的增加&#xff0c;应用可能会变得…

51单片机Proteus仿真速成教程——P1-软件与配置+Proteus绘制51单片机最小系统+新建程序模版

前言&#xff1a;本文主要围绕 51 单片机最小系统的绘制及程序模板创建展开。首先介绍了使用 Proteus 绘制 51 单片机最小系统的详细步骤&#xff0c;包括软件安装获取途径、工程创建、器件添加&#xff08;如单片机 AT89C51、晶振、电容、电阻、按键等&#xff09;、外围电路&…