SQL-正则表达式和约束

这篇具有很好参考价值的文章主要介绍了SQL-正则表达式和约束。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

主要内容

  1. 正则表达式
  2. 约束

一.正则表达式

正则表达式是一种用来描述字符串模式的工具,它可以用于匹配、查找、替换等操作。正则表达式由字符和特殊字符组成,可以使用这些字符来定义匹配规则。

常用的正则表达式字符和特殊字符有:

  1. 普通字符:表示匹配该字符本身,如a表示匹配字母"a"。
  2. 元字符:具有特殊含义的字符,如.表示匹配除换行符以外的任意字符。
  3. 字符类:用[]表示,表示匹配括号内的任意一个字符,如[abc]表示匹配字符"a"、“b"或"c”。
  4. 反义字符类:用[^]表示,表示匹配除括号内字符以外的任意字符,如[^abc]表示匹配除"a"、“b”、"c"以外的任意字符。
  5. 重复字符:用*+?表示,分别表示匹配前一个字符0次或多次、1次或多次、0次或1次。
  6. 边界匹配:用^$表示,分别表示匹配字符串的开头和结尾。
  7. 分组:用()表示,可以将多个字符组合为一个整体,如(ab)+表示匹配"ab"、“abab”、"ababab"等。
  8. 转义字符:用\表示,可以将特殊字符转义为普通字符,如\.表示匹配字符"."。

正则表达式的用法有:

  1. 匹配:使用match()函数可以在字符串中查找匹配正则表达式的部分,并返回一个包含匹配结果的数组。
  2. 查找:使用search()函数可以在字符串中查找匹配正则表达式的部分,并返回第一个匹配的位置。
  3. 替换:使用replace()函数可以将字符串中匹配正则表达式的部分替换为指定的内容。
  4. 分割:使用split()函数可以根据正则表达式将字符串分割为多个部分,并返回一个数组。

其他用法

  1. 量词:用来指定前面的字符或字符类的重复次数。常用的量词有:

    • *:匹配前一个字符0次或多次。
    • +:匹配前一个字符1次或多次。
    • ?:匹配前一个字符0次或1次。
    • {n}:匹配前一个字符恰好n次。
    • {n,}:匹配前一个字符至少n次。
    • {n,m}:匹配前一个字符至少n次,最多m次。
  2. 特殊字符:

    • .:匹配除换行符以外的任意字符。
    • \d:匹配数字字符。
    • \D:匹配非数字字符。
    • \w:匹配字母、数字、下划线字符。
    • \W:匹配非字母、数字、下划线字符。
    • \s:匹配空白字符(空格、制表符、换行符等)。
    • \S:匹配非空白字符。
    • \b:匹配单词边界。
    • \B:匹配非单词边界。
  3. 分组和引用:

    • ():将多个字符组合为一个整体。
    • (?:):非捕获分组,用于只匹配但不捕获。
    • \1\2、…:引用前面的分组,用于匹配相同的内容。
  4. 断言:

    • (?=...):正向肯定前瞻,用于匹配满足某个条件的位置。
    • (?!...):正向否定前瞻,用于匹配不满足某个条件的位置。
    • (?<=...):反向肯定后顾,用于匹配位于某个条件之后的位置。
    • (?<!...):反向否定后顾,用于匹配不位于某个条件之后的位置。

SQL-正则表达式和约束,SQL,sql,正则表达式,mysql,数据库,运维
SQL-正则表达式和约束,SQL,sql,正则表达式,mysql,数据库,运维

正则表达式的用法非常灵活,可以根据具体的需求来选择合适的字符、特殊字符、量词、分组等来构建匹配规则。同时,正则表达式还支持一些高级的特性,如贪婪模式、非贪婪模式、修饰符等,可以进一步扩展正则表达式的功能。

正则表达式的详细用法还有很多,可以根据具体的需求来选择合适的正则表达式和相应的函数来进行操作。

1.操作1

代码如下(示例):
-- ^ 在字符串开始处进行匹配
SELECT 'abc' REGEXP '^a';
-- $ 在字符串末尾开始匹配
SELECT 'abc' REGEXP 'a$';
SELECT 'abc' REGEXP 'c$’;
-- . 匹配任意字符
SELECT 'abc' REGEXP '.b';
SELECT 'abc' REGEXP '.c';
SELECT 'abc' REGEXP 'a.';
-- [...] 匹配括号内的任意单个字符
SELECT 'abc' REGEXP '[xyz]';
SELECT 'abc' REGEXP '[xaz]';

2.操作2

代码如下(示例):
-- [^...] 注意 ^ 符合只有在 [] 内才是取反的意思,在别的地方都是表示开始处匹配
SELECT 'a' REGEXP '[^abc]';
SELECT 'x' REGEXP '[^abc]';
SELECT 'abc' REGEXP '[^a]';
-- a* 匹配 0 个或多个 a, 包括空字符串。 可以作为占位符使用 . 有没有指定字符都可以匹配
到数据
SELECT 'stab' REGEXP '.ta*b';
SELECT 'stb' REGEXP '.ta*b';
SELECT '' REGEXP 'a*';
-- a+ 匹配 1 个或者多个 a, 但是不包括空字符
SELECT 'stab' REGEXP '.ta+b';
SELECT 'stb' REGEXP '.ta+b';

3.操作3

代码如下(示例):
-- [^...] 注意 ^ 符合只有在 [] 内才是取反的意思,在别的地方都是表示开始处匹配
SELECT 'a' REGEXP '[^abc]';
SELECT 'x' REGEXP '[^abc]';
SELECT 'abc' REGEXP '[^a]';
-- a* 匹配 0 个或多个 a, 包括空字符串。 可以作为占位符使用 . 有没有指定字符都可以匹配
到数据
SELECT 'stab' REGEXP '.ta*b';
SELECT 'stb' REGEXP '.ta*b';
SELECT '' REGEXP 'a*';
-- a+ 匹配 1 个或者多个 a, 但是不包括空字符
SELECT 'stab' REGEXP '.ta+b';
SELECT 'stb' REGEXP '.ta+b';

4.操作4

代码如下(示例):
-- a{m,n} 匹配 m 到 n 个 a, 包含 m 和 n
SELECT 'auuuuc' REGEXP 'au{3,5}c';
SELECT 'auuuuc' REGEXP 'au{4,5}c';
SELECT 'auuuuc' REGEXP 'au{5,10}c';
-- (abc) abc 作为一个序列匹配,不用括号括起来都是用单个字符去匹配,如果要把多个字符
作为一个整体去匹配就需要用到括号,所以括号适合上面的所有情况。
SELECT 'xababy' REGEXP 'x(abab)y';
SELECT 'xababy' REGEXP 'x(ab)*y';
SELECT 'xababy' REGEXP 'x(ab){1,2}y';

二.约束

SQL约束是用于限制数据库表中数据的完整性和一致性的规则。它们定义了对表中数据的操作所允许的条件和限制。约束可以应用于表的列或整个表。

约束的分类:

  1. 主键约束(Primary Key Constraint):用于标识表中的唯一记录。主键约束要求列中的值是唯一的且不为空。
  2. 外键约束(Foreign Key Constraint):用于建立表之间的关系。外键约束要求一个表的列的值必须是另一个表的主键值。
  3. 唯一约束(Unique Constraint):用于确保列中的值是唯一的。唯一约束要求列中的值不能重复。
  4. 非空约束(Not Null Constraint):用于确保列中的值不为空。非空约束要求列中的值不能为NULL。
  5. 检查约束(Check Constraint):用于定义列中值的范围或条件。检查约束要求列中的值必须满足指定的条件。

约束的作用:

  1. 数据完整性:约束可以确保表中的数据满足特定的条件和规则,防止无效或不一致的数据进入数据库。
  2. 数据一致性:约束可以确保表之间的关系是正确的,避免了数据冗余和不一致。
  3. 数据安全性:约束可以防止对表中数据的非法操作,保护数据的安全性。

约束的用法:

  1. 创建约束:在创建表时,可以使用CREATE TABLE语句来定义约束。例如,可以使用PRIMARY KEY关键字定义主键约束,使用UNIQUE关键字定义唯一约束,使用FOREIGN KEY关键字定义外键约束等。
  2. 修改约束:可以使用ALTER TABLE语句来修改表的约束。例如,可以使用ADD CONSTRAINT关键字来添加新的约束,使用DROP CONSTRAINT关键字来删除约束等。
  3. 禁用约束:可以使用ALTER TABLE语句来禁用约束。例如,可以使用DISABLE CONSTRAINT关键字来禁用约束,以便在需要时可以绕过约束进行操作。
  4. 启用约束:可以使用ALTER TABLE语句来启用约束。例如,可以使用ENABLE CONSTRAINT关键字来启用约束,以便在禁用后重新启用约束。

总结起来,SQL约束是用于限制数据库表中数据的完整性和一致性的规则。它们可以应用于表的列或整个表,通过定义特定的条件和规则来确保数据的有效性和安全性。

1.主键约束

添加单列主键

方法1:
--在create table语句时,通过primary key
-- 在定义字段的同时指定主键,语法格式如下:
create table 表名 (
	...
	< 字段名 > < 数据类型 > primary key
	...
)

方式 1- 实现:
create table emp1(
	eid int primay key,
	name VARCHAR(20),
	deptId int,
	salary double
);

方法2-- 在定义字段之后再指定主键,语法格式如下:
create table 表名 (
	...
	[constraint < 约束名 >] primary key [ 字段名]
);

方式 2- 实现:
create table emp2(
	eid INT,
	name VARCHAR(20),
	deptId INT,
	salary double,
	constraint pk1 primary key(id)
);

添加多列主键(联合主键)

语法:
create table 表名(
	...
	primary key (字段1,字段2...,字段n);

实现:
create table emp3(
	name varchar(20),
	deptId int,
	salary double,
	primary key(name,deptId)
);

通过修改表结构添加主键

主键约束不仅可以在创建表的同时创建,也可以在修改表时添加。

语法;
create table 表名 (
	...
);
alter table < 表名 > add primary key (字段列表 );

实现:
-- 添加单列主键
create table emp4(
	eid int,
	name varchar(20),
	deptId int,
	salary double,
);
alter table emp4 add primary key ( eid);

删除主键约束

格式:
alter table <数据表名> drop primary key;

实现:
-- 删除单列主键
alter table emp1 drop primary key;
-- 删除联合主键
alter table emp5 drop primary key;

2.自增长约束

在 MySQL中,当主键定义为自增长后,这个主键的值就不再需要用户输入数据了,而由数据库系统根据定义自动赋值。每增加一条记录,主键会自动以相同的步长进行增长。
通过给字段添加 auto_increment 属性来实现主键自增长

语法:
字段名 数据类型 auto_increment

实现:
create table t_user1(
	id int primary key auto_increment,
	name varchar(20)
);

特点:

  • 默认情况下, auto_increment 的初始值是 1 ,每新增一条记录,字段值自动加 1 。
  • 一个表中只能有一个字段使用auto_increment 约束,且该字段必须有唯一索引,以避免序号重复(即为主键或 主键的一部分)。
  • auto_increment约束的字段必须具备 NOT NULL 属性。 auto_increment 约束的字段只能是整数类型( TINYINT 、SMALLINT 、 INT 、 BIGINT 等。
  • auto_increment 约束字段的最大值受该字段的数据类型约束,如果达到上限, auto_increment 就会失效。

指定自增字段初始值

-- 方式 1 ,创建表时指定
create table t_user2 (
	id int primary key auto_increment,
	name varchar(20)
)auto_increment=100;

--方式2,创建表之后指定
create table t_user3 (
	id int primary key auto_increment,
	name varchar(20)
);
alter table t_user2 auto_increment=100;

delete 和 truncate 在删除后自增列的变化:
delete:数据之后自动增长从断点开始
truncate:数据之后自动增长从默认起始值开始

3.非空约束

语法:
方式 1< 字段名 >< 数据类型 > not null;
方式 2alter table 表名 modify 字段 类型 not null;

添加非空约束
--方法1,创建表时指定
create table t_user6 (
	id int ,
	name varchar(20) not null,
	address varchar(20) not null
);

--方法2,之后指定
create table t_user7 (
	id int ,
	name varchar(20) , -- 指定非空约束
	address varchar(20) -- 指定非空约束
);
alter table t_user7 modify name varchar(20) not null;
alter table t_user7 modify address varchar(20) not null;

删除非空约束:
-- alter table 表名 modify 字段 类型
alter table t_user7 modify name varchar(20) ;
alter table t_user7 modify address varchar(20) ;

4.唯一约束

代码如下(示例):
语法:
方式 1< 字段名 > < 数据类型 > unique
方式 2alter table 表名 add constraint 约束名 unique();

添加唯一约束 - 方式 1
-- 创建表时指定
create table t_user8 (
	id int ,
	name varchar(20) ,
	phone_number varchar(20) unique -- 指定唯一约束
);

添加唯一约束 - 方式 2
create table t_user9 (
	id int ,
	name varchar(20) ,
	phone_number varchar(20) -- 指定唯一约束
);
alter table t_user9 add constraint unique_ph unique(phone_number);

删除唯一约束
-- alter table < 表名 > drop index < 唯一约束名 >;
alter table t_user9 drop index unique_ph;

5.默认约束

语法
方式 1< 字段名 > < 数据类型 > default < 默认值 >;
方式 2: alter table 表名 modify 列名 类型 default 默认值 ;

添加默认约束 - 方式 1

create table t_user10 (
id int ,
name varchar(20) ,
address varchar(20) default ‘ 北京’ -- 指定默认约束
);

添加默认约束 - 方式 2
--alter table 表名 modify 列名 类型 default 默认值
create table t_user11 (
	id int ,
	name varchar(20) ,
	address varchar(20)
);
alter table t_user11 modify address varchar(20) default ‘ 北京’ ;

删除默认约束
-- alter table < 表名 > modify column < 字段名 > < 类型 > default null;
alter table t_user11 modify column address varchar(20) default null;

6.零填充约束

  • 插入数据时,当该字段的值的长度小于定义的长度时,会在该值的前面补上相应的 0
  • zerofill 默认为 int(10)
  • 当使用 zerofill 时,默认会自动加 unsigned (无符号)属性,使用 unsigned 属性后,数值范围 是原值的 2 倍,例如,有符号为 -128~+127 ,无符号为 0~256 。
代码如下(示例):
create table t_user12 (
	id int zerofill , -- 零填充约束
	name varchar(20)
);

删除
alter table t_user12 modify id int;

总结

MySQL的视图
以上是今天要讲的内容,学到了正则表达式和约束,包括正则表达式的字符和特殊字符,约束的分类,约束的作用,约束的用法。文章来源地址https://www.toymoban.com/news/detail-716673.html

到了这里,关于SQL-正则表达式和约束的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • notepad++配合正则表达式分组模式处理文本转化为sql语句

    一、正则分组知识点补充 正则分组和捕获 ():用于分组和捕获子表达式。 大白话就是()匹配到的数据,通过美元符号加下标可以获取该数据,例如$1、$2, 下标从1开始。 下面的案例就采用该模式处理文本数据 二、使用正则的需求背景 有一份报表的数据,需要把数据入库到m

    2024年02月07日
    浏览(60)
  • ABAP SQL & CDSView Entity中使用正则RegEx表达式(Regular Expressions)

    DEMO_REGEX DEMO_REGEX_TOY SQL函数 语法 作用 执行逻辑 返回类型 CDS   View Entities ABAP   SQL LIKE_REGEXPR LIKE_REGEXPR(            PCRE = pcre,            VALUE = sql_exp1[,            CASE_SENSITIVE = case]) 检查字符串是否包含任何 PCRE命中 检查sql_exp是否包含任何   PCRE命中,是则返

    2024年01月24日
    浏览(36)
  • QT QLineEdit 只能输入字母或数字,输入格式约束(正则表达式)

    1.只允许输入整型 ui-lineEdit-setValidator(new QIntValidator(ui-lineEdit)); 1 2.只允许输入数字 ui-lineEdit-setValidator(new QRegExpValidator(QRegExp(\\\"[0-9]+$\\\")));    1 3.只能输入字母和数字 ui-lineEdit-setValidator(new QRegExpValidator(QRegExp(\\\"[a-zA-Z0-9]+$\\\")));    1 3.1 只能输入大写数据: ui-lineEdit-setValidator(new QRegE

    2024年02月04日
    浏览(43)
  • MySQL正则表达式 | 事务详解

    目录 一、正则表达式 实例操作 二、事务 事务控制语句 MYSQL 事务处理主要有两种方法 SQL测试代码 PHP中使用事务实例 使用保留点 SAVEPOINT MySQL可以通过  LIKE ...%  来进行模糊匹配。 MySQL 同样也支持其他正则表达式的匹配, MySQL中使用 REGEXP 操作符来进行正则表达式匹配。 如果

    2023年04月18日
    浏览(35)
  • MySQL正则表达式检索数据

    目录 一、使用正则表达式进行基本字符匹配 1.使用regexp 2.使用正则表达式  .  二、进行OR匹配 1.为搜索两个串之一,使用   |   2.匹配几个字符之一[] 3.匹配范围  4.匹配特殊字符 过滤数据允许使用 匹配、比较、通配符 操作来寻找数据,但是随着过滤条件的复杂性增

    2024年02月14日
    浏览(37)
  • mysql 正则表达式 提取 指定字符

    eg: 使用正则表达式来进行匹配替换: REGEXP_REPLACE(\\\'需要进行替换的字段‘, ‘被替换的’,‘替换的内容’) eg: 模式 说明 ^ 匹配输入字符串的开始位置。如果设置了 RegExp 对象的 Multiline 属性,^ 也匹配 ‘n’ 或 ‘r’ 之后的位置。 $ 匹配输入字符串的结束位置。

    2024年02月06日
    浏览(49)
  • 【MySQL】不允许你不会用正则表达式进行搜索

    🎬 博客主页:博主链接 🎥 本文由 M malloc 原创,首发于 CSDN🙉 🎄 学习专栏推荐:LeetCode刷题集! 🏅 欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正! 📆 未来很长,值得我们全力奔赴更美好的生活✨ 😁大家好呀,今天是我第N次写MySQL,也是最近才学习MySQL,也想着记录

    2024年02月11日
    浏览(55)
  • sql进阶 之case表达式

    CASE表达式是SQL里非常重要而且使用起来非常便利的技术,我们应该学会用它来描述条件分支。本节将通过 行列转换、已有数据重分组(分类)、与约束的结合使用、针对聚合结果的条件分支 等例题,来介绍CASE表达式的用法。标红即为他的作用 先读如下文章 明白mysql是行引

    2024年02月15日
    浏览(38)
  • 【SQL篇】窗口函数和公共表达式

    思路 先给每个数进行排名 用这些数减去自己的排名,如果减了之后的结果是一样的,说明这几个数是连续的 用logid减去排名得出来的数进行group by,也就是把连续的数全都放在一个一个小组里面,求出每个小组的最大值和最小值就可以了 1596题 总结 这里有个坑,count并不会根

    2024年02月02日
    浏览(40)
  • 如何使用SQL系列 之 如何在SQL中使用CASE表达式

    编程语言通常以 条件语句 为特征,它们是执行特定操作直到满足特定条件的命令。一个常见的条件语句是 if, then, else 语句,它通常遵循以下逻辑: 这条语句的逻辑可以翻译成如下语言:“如果 condition 为真,那么perform action A 。否则(else),执行 动作B 。” CASE 表达式是结构化查

    2024年02月09日
    浏览(55)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包