Validate url with a check constraint(使用检查约束验证 url)
问题描述
我想创建一个验证 url 的 CHECK CONSTRAINT
.
I would like to create a CHECK CONSTRAINT
which validates the url.
这是我的第一种方法,但它也需要标签.
Here is my first approach, but it also takes hashtags.
CHECK ([ServiceURL] LIKE 'https://[a-z0-9]%.[a-z0-9]%')
另一个想法是这个
CHECK ([ServiceURL] LIKE 'https://[a-z0-9].[a-z0-9]')
但这也行不通.有什么想法吗?
But this doesn't work as well. any ideas?
推荐答案
进一步以 Gary 的例子为例,下面的版本展示了我们如何在不使用游标的情况下编写函数以及如何将检查约束添加到表中.您可能希望扩展它以处理 http 和 https,以及可能的其他修改(例如允许/字符)
Taking Gary's example further, the version below shows how we can write the function without the use of a cursor and how we can add the check constraint to the table. You'd likely want to extend this to cope with http as well as https, and possibly other modifications (like allowing the / character)
CREATE FUNCTION dbo.IsValidURL (@Url VARCHAR(200))
RETURNS INT
AS
BEGIN
IF CHARINDEX('https://', @url) <> 1
BEGIN
RETURN 0; -- Not a valid URL
END
-- Get rid of the http:// stuff
SET @Url = REPLACE(@URL, 'https://', '');
-- Now we need to check that we only have digits or numbers
IF (@Url LIKE '%[^a-zA-Z0-9]%')
BEGIN
RETURN 0;
END
-- It is a valid URL
RETURN 1;
END
-- Create the table
CREATE TABLE dbo.MyTableOnlyLettersAndDigits
(
id int identity(1,1) primary key clustered,
ServiceURL varchar(200) not null
);
GO
-- Add the check constraint
ALTER TABLE dbo.MyTableOnlyLettersAndDigits
ADD CONSTRAINT chkValidURLs CHECK (dbo.IsValidURL(ServiceURL) = 1);
-- Some tests to show it works
insert into dbo.MyTableOnlyLettersAndDigits(ServiceURL)
values ('Missing prefix.Invalid');
insert into dbo.MyTableOnlyLettersAndDigits(ServiceURL)
values ('https://IamAValidURL123');
insert into dbo.MyTableOnlyLettersAndDigits(ServiceURL)
values ('https://Invalid#Char');
这篇关于使用检查约束验证 url的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:使用检查约束验证 url


- 如何将 Byte[] 插入 SQL Server VARBINARY 列 2021-01-01
- 如何将 SonarQube 6.7 从 MySQL 迁移到 postgresql 2022-01-01
- SQL 临时表问题 2022-01-01
- 使用 Oracle PL/SQL developer 生成测试数据 2021-01-01
- 在SQL中,如何为每个组选择前2行 2021-01-01
- 如何使用 pip 安装 Python MySQLdb 模块? 2021-01-01
- 远程 mySQL 连接抛出“无法使用旧的不安全身份验证连接到 MySQL 4.1+"来自 XAMPP 的错误 2022-01-01
- 更改自动增量起始编号? 2021-01-01
- 导入具有可变标题的 Excel 文件 2021-01-01
- 以一个值为轴心,但将一行上的数据按另一行分组? 2022-01-01