mysql uniqueidentifier,sql-如何检查字符串是否为uniqueidentifier?

mysql uniqueidentifier,sql-如何检查字符串是否为uniqueidentifier?sql-如何检查字符串是否为uniqueidentifier?是否有与IsDate或IsNumeric等效的uniqueidentifier(SQLServer)?还是有等同于(C#)TryParse的东西?否则,我将不得不编写自己的函数,但是我想确保自己没有重新发明轮子。我要介绍的场景如下:SELECTsomethingFROMtableWHEREIsUniqueidentifier…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

sql-如何检查字符串是否为uniqueidentifier?

是否有与IsDate或IsNumeric等效的uniqueidentifier(SQL Server)?还是有等同于(C#)TryParse的东西?

否则,我将不得不编写自己的函数,但是我想确保自己没有重新发明轮子。

我要介绍的场景如下:

SELECT something FROM table WHERE IsUniqueidentifier(column) = 1

Benoittr asked 2020-01-23T02:27:19Z

12个解决方案

63 votes

SQL Server 2012通过WHERE使这一切变得更加容易

SELECT something

FROM your_table

WHERE TRY_CONVERT(UNIQUEIDENTIFIER, your_column) IS NOT NULL;

对于早期版本的SQL Server,现有答案缺少几点,这意味着它们可能与SQL Server实际上会毫无疑问地转换为WHERE的字符串不匹配,或者可能最终导致无效的转换错误。

SQL Server接受包含在WHERE中或不包含在其中的GUID。

此外,它会忽略字符串末尾的多余字符。 例如,WHERE和À都成功。

在大多数默认归类下,WHERE将最终匹配字符,例如À或Ë

最后,如果将结果中的行强制转换为uniqueidentifier,将强制转换尝试放在case表达式中非常重要,因为强制转换可能发生在WHERE行过滤之前。

因此(借用@ r0d30b0y的想法)可能会更健壮一些

;WITH T(C)

AS (SELECT ‘5D944516-98E6-44C5-849F-9C277833C01B’

UNION ALL

SELECT ‘{5D944516-98E6-44C5-849F-9C277833C01B}’

UNION ALL

SELECT ‘5D944516-98E6-44C5-849F-9C277833C01BXXXXXXXXXXXXXXXXXXXXXXXXXXXXX’

UNION ALL

SELECT ‘{5D944516-98E6-44C5-849F-9C277833C01B}ssssssssss’

UNION ALL

SELECT ‘ÀD944516-98E6-44C5-849F-9C277833C01B’

UNION ALL

SELECT ‘fish’)

SELECT CASE

WHEN C LIKE expression + ‘%’

OR C LIKE ‘{‘ + expression + ‘}%’ THEN CAST(C AS UNIQUEIDENTIFIER)

END

FROM T

CROSS APPLY (SELECT REPLACE(‘00000000-0000-0000-0000-000000000000’, ‘0’, ‘[0-9a-fA-F]’) COLLATE Latin1_General_BIN) C2(expression)

WHERE C LIKE expression + ‘%’

OR C LIKE ‘{‘ + expression + ‘}%’

Martin Smith answered 2020-01-23T02:27:57Z

58 votes

不是我的,在网上找到了这个……我想分享。

SELECT 1 WHERE @StringToCompare LIKE

REPLACE(‘00000000-0000-0000-0000-000000000000’, ‘0’, ‘[0-9a-fA-F]’);

r0d30b0y answered 2020-01-23T02:28:17Z

24 votes

SELECT something

FROM table1

WHERE column1 LIKE ‘[0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F]-[0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F]-[0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F]-[0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F]-[0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F]’;

更新:

…但是我更喜欢@ r0d30b0y的答案中的方法:

SELECT something

FROM table1

WHERE column1 LIKE REPLACE(‘00000000-0000-0000-0000-000000000000’, ‘0’, ‘[0-9a-fA-F]’);

onedaywhen answered 2020-01-23T02:28:41Z

4 votes

我不知道您可以“开箱即用”使用任何东西-恐怕您必须自己编写。

如果可以:尝试将其编写在C#库中并将其作为SQL-CLR程序集部署到SQL Server中-那么您可以使用像Guid.TryParse()这样的东西,它肯定比T-SQL中的任何东西都容易使用。

marc_s answered 2020-01-23T02:29:06Z

2 votes

r0d30b0y答案的一种变体是使用PATINDEX在字符串中查找…

PATINDEX(‘%’+REPLACE(‘00000000-0000-0000-0000-000000000000’, ‘0’, ‘[0-9a-fA-F]’)+’%’,@StringToCompare) > 0

曾用于在URL字符串中查找Guid。

高温超导

戴夫

Dave answered 2020-01-23T02:29:39Z

2 votes

喜欢保持简单。 一个GUID包含四个-即使只是一个字符串也包含在内

WHERE栏,例如’%-%-%-%-%’

Mike answered 2020-01-23T02:30:03Z

1 votes

这是基于一些早期注释概念的功能。 这个功能非常快。

CREATE FUNCTION [dbo].[IsGuid] (@input varchar(50))

RETURNS bit AS

BEGIN

RETURN

case when @input like ‘[0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F]-[0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F]-[0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F]-[0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F]-[0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F]’

then 1 else 0 end

END

GO

/*

Usage:

select [dbo].[IsGuid](‘123’) — Returns 0

select [dbo].[IsGuid](‘ebd8aebd-7ea3-439d-a7bc-e009dee0eae0’) — Returns 1

select * from SomeTable where dbo.IsGuid(TableField) = 0 — Returns table with all non convertable items!

*/

Ansonmus answered 2020-01-23T02:30:23Z

1 votes

虽然是较早的帖子,但只是想快速测试一下…

SELECT [A].[INPUT],

CAST([A].[INPUT] AS [UNIQUEIDENTIFIER])

FROM (

SELECT ‘5D944516-98E6-44C5-849F-9C277833C01B’ Collate Latin1_General_100_BIN AS [INPUT]

UNION ALL

SELECT ‘{5D944516-98E6-44C5-849F-9C277833C01B}’

UNION ALL

SELECT ‘5D944516-98E6-44C5-849F-9C277833C01BXXXXXXXXXXXXXXXXXXXXXXXXXXXXX’

UNION ALL

SELECT ‘{5D944516-98E6-44C5-849F-9C277833C01B}ssssssssss’

UNION ALL

SELECT ‘ÀD944516-98E6-44C5-849F-9C277833C01B’

UNION ALL

SELECT ‘fish’

) [A]

WHERE PATINDEX(‘[^0-9A-F-{}]%’, [A].[INPUT]) = 0

Geary M. McIver answered 2020-01-23T02:30:43Z

0 votes

您可以编写自己的UDF。 这是一个简单的近似值,以避免使用SQL-CLR程序集。

CREATE FUNCTION dbo.isuniqueidentifier (@ui varchar(50))

RETURNS bit AS

BEGIN

RETURN case when

substring(@ui,9,1)=’-‘ and

substring(@ui,14,1)=’-‘ and

substring(@ui,19,1)=’-‘ and

substring(@ui,24,1)=’-‘ and

len(@ui) = 36 then 1 else 0 end

END

GO

然后,您可以对其进行改进,以检查它是否仅与十六进制值有关。

pcofre answered 2020-01-23T02:31:08Z

0 votes

我用 :

ISNULL(convert(nvarchar(50), userID), ‘NULL’) = ‘NULL’

Villie answered 2020-01-23T02:31:27Z

0 votes

我有一些用AutoFixture生成的Test用户,默认情况下,这些用户使用GUID生成字段。 我需要删除的用户的“我的名字”字段是GUID或uniqueidentifier。 我就是这样结束的。

我能够将您的一些答案汇总到此。

SELECT UserId FROM [Membership].[UserInfo] Where TRY_CONVERT(uniqueidentifier, FirstName) is not null

Don Rolling answered 2020-01-23T02:31:56Z

0 votes

将RLIKE用于MYSQL

SELECT 1 WHERE @StringToCompare

RLIKE REPLACE(‘00000000-0000-0000-0000-000000000000’, ‘0’, ‘[0-9a-fA-F]’);

ks1bbk answered 2020-01-23T02:32:16Z

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/195892.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 微信聊天记录迁移(Android到IOS)「建议收藏」

    微信聊天记录迁移1.原设备登录微信我的–>设置–>通用–>聊天记录备份与迁移选择“迁移聊天记录到另一台设备”选择“迁移全部聊天记录”,会生成一个二维码用新的设备登录该微信号并扫描此二维码,即可迁移数据…

    2022年4月15日
    211
  • XSD文件结构详解「建议收藏」

    XSD文件结构详解「建议收藏」XSD(xmlSchemaDefinition)XmlSchema的用途1.  定义一个Xml文档中都有什么元素2.  定义一个Xml文档中都会有什么属性3.  定义某个节点的都有什么样的子节点,可以有多少个子节点,子节点出现的顺序4.  定义元素或者属性的数据类型5.  定义元素或者属性的默认值或者固定值XmlSchema的根元素:<?xmlversion="1.0"?>…

    2022年10月25日
    0
  • TiDB 在银行核心金融领域的研究与两地三中心实践

    TiDB 在银行核心金融领域的研究与两地三中心实践作者介绍:于振华,北京银行软件开发部资深架构师,长期从事银行核心系统研发、规划,参与过多个核心信息系统建设工作,包括一、二代支付系统、第四代银行核心系统建设、分布式核心系统建设等企业级项目工作。当前主要研发方向集中在构建先进、高效、面向OLTP的银行交易系统,提升银行信息系统服务能力。本文整理自于振华老师在TiDBDevCon2019上的演讲实录,演讲主题为《TiDB在…

    2022年6月17日
    80
  • vmware workstation15.5 密钥_senorita是哪国语言

    vmware workstation15.5 密钥_senorita是哪国语言Workstation 11.0.0多国语言(含简体中文)+永久激活密钥”alt=”VMware Workstation 11.0.0多国语言(含简体中文)+永久激活密钥”src=”http://s7.sinaimg.cn/mw690/001gFAKHgy6O5Pq5emy06&690″width=”690″height=”239″> 昨天,VMware虚拟机11.0简体中文版正式

    2022年9月14日
    0
  • fastjson解析多层json_fastjson github

    fastjson解析多层json_fastjson github一、前言通过alibaba的fastjson包中的com.alibaba.fastjson.JSONArray、com.alibaba.fastjson.JSONObject定义JsonObjectUtil对象工具类,实现object转换成JSON的convertMapToJson、JSON转换成Map的convertJsonToMap、判断JSONObject/JSONArray对象是否为空is…

    2022年9月27日
    0
  • 大批量数据excel下载—本文作者只试了51万数据的下载,用时7秒

    一.背景:现在的项目里,有诸多下载功能,随着数据越来越多,下载的时间也越来越长,很影响用户体验,为了解决这一问题,我不得不挺身而出,斩破难关。项目中原本用的是poi-HSSFWorkbook,但是如果是50万数据量下载,回经历一个漫长的等待过程,然后内存溢出。jxl也不用想了,估计也差不多。二.两种方法:后来从网上搜索发现针对大数据量的导出有两条路可以走:第一:用poi-SXSSFWo

    2022年4月4日
    40

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号