狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

SQL Server函數:charindex和patindex的用法

admin
2024年11月13日 19:37 本文熱度 438

Microsoft SQL Server中,CHARINDEX?函數用于在一個字符串中查找另一個指定字符串的起始位置。如果找到,返回指定字符串在源字符串中的起始位置索引(從?1?開始計數);如果沒找到,則返回?0。

基本語法:

charindex(expressionToFind, expressionToSearch [, start_location ])

expressionToFind:?目標字符串,就是想要找到的字符串,最大長度為8000?

expressionToSearch:?用于被查找的字符串。

start_location(可選):?開始查找的位置,為空時默認從第一位開始查找。

1、簡單測試:

select charindex('test','this Test is Test') as 位置

結果為6

2、增加開始位置,但結果還是從前往后數

select charindex('test','this Test is Test',7) as 位置

結果為14

3、大小寫敏感

select charindex('test','this Test is Test'COLLATE Latin1_General_CS_AS) as 位置

結果為0

4、大小寫不敏感,CICase-InSensitve的縮寫

select charindex('Test','this Test is Test'COLLATE Latin1_General_CI_AS) as 位置

結果為6

5、提取第一個分號前的內容

WITH a1 (col) AS(SELECT '測試2;建軍節' UNION ALLSELECT '測試3;' UNION ALLSELECT '測試12;' UNION ALLSELECT '測試13;建軍節;')select CASE  ?WHEN charindex(';',col) > 0  ?THEN left(col,charindex(';',col)) END colFROM?a1

結果為:

測試2;

測試3;

測試12;

測試13;

PATINDEXCHARINDEX類似,PATINDEX也可以用來判斷一個字符串中是否包含另一個字符串,二者的差異在于,前者是全匹配,后者支持模糊匹配。

基本語法:

PATINDEX ( '%pattern%', expression )

%pattern%:這是包含通配符的模式字符串。通配符“%”表示零個或多個字符。例如“% abc%”?可以匹配包含“abc”的任何字符串,像“xabc”“abcdef”等。

expression:這是要在其中查找模式的源字符串。

例如:

select patindex('%ter%','interesting data') as 位置

結果為3

select patindex('%t_ng%','interesting data') as 位置

結果為8

注意:

1、在大多數簡單的、沒有通配符的字符串查找場景中,CHARINDEX?函數的效率通常更高。因為?CHARINDEX?只需要進行基本的字符串逐字符匹配,而?PATINDEX?函數由于要處理可能存在的通配符和復雜的模式匹配規則,會涉及更復雜的邏輯處理。

2MySQL?不支持charindexpatindex函數,但有類似功能的函數。


該文章在 2024/11/14 11:40:42 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved