」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何在SQL Server 2012中實作MySQL的SUBSTRING_INDEX功能?

如何在SQL Server 2012中實作MySQL的SUBSTRING_INDEX功能?

發佈於2024-12-21
瀏覽:580

How to Achieve MySQL's SUBSTRING_INDEX Functionality in SQL Server 2012?

MySQL 中substring_index 函數的SQL Server 等效項

MySQL 中的substring_index 函數用於從給定字串之前的指定字元串中提取子字串分隔符號出現的次數。若要在 SQL Server 2012 中實作類似的功能,您可以採用下列方法之一:

T-SQL 標量函數:

CREATE FUNCTION dbo.SUBSTRING_INDEX
(
    @str NVARCHAR(4000),
    @delim NVARCHAR(1),
    @count INT
)
RETURNS NVARCHAR(4000)
WITH SCHEMABINDING
BEGIN
    -- Convert the string to an XML document for processing
    DECLARE @XmlSourceString XML;
    SET @XmlSourceString = (SELECT N'<root><row>'   REPLACE( (SELECT @str AS '*' FOR XML PATH('')) , @delim, N'</row><row>' )   N'</row></root>');

    -- Extract the desired substring using XQuery
    RETURN STUFF
    (
        ((
            SELECT  @delim   x.XmlCol.value(N'(text())[1]', N'NVARCHAR(4000)') AS '*'
            FROM    @XmlSourceString.nodes(N'(root/row)[position() <= sql:variable("@count")]') x(XmlCol)
            FOR XML PATH(N''), TYPE
        ).value(N'.', N'NVARCHAR(4000)')), 
        1, 1, N''
    );
END
GO

-- Example usage
SELECT dbo.SUBSTRING_INDEX(N'www.somewebsite.com', N'.', 2) AS Result;

T-SQL 內聯表值函數:

CREATE FUNCTION dbo.SUBSTRING_INDEX
(
    @str NVARCHAR(4000),
    @delim NVARCHAR(1),
    @count INT
)
RETURNS TABLE
AS 
RETURN
    WITH Base
    AS 
    (
        SELECT XmlSourceString = CONVERT(XML, (SELECT N'<root><row>'   REPLACE( (SELECT @str AS '*' FOR XML PATH('')) , @delim, N'</row><row>' )   N'</row></root>'))
    )   
    SELECT STUFF
    (
        ((
            SELECT  @delim   x.XmlCol.value(N'(text())[1]', N'NVARCHAR(4000)') AS '*'
            FROM    Base b 
            CROSS APPLY b.XmlSourceString.nodes(N'(root/row)[position() <= sql:variable("@count")]') x(XmlCol)
            FOR XML PATH(N''), TYPE
        ).value(N'.', N'NVARCHAR(4000)')), 
        1, 1, N''
    ) AS Result;
GO

-- Example usage
SELECT  *
FROM    (
    SELECT N'www.somewebsite.com' UNION ALL 
    SELECT N'www.yahoo.com' UNION ALL 
    SELECT N'www.outlook.com'
) a(Value)
CROSS APPLY dbo.SUBSTRING_INDEX(a.Value, N'.', 2) b;

這些函數可讓您複製SQL Server 中MySQL substring_index 函數的行為,讓您能夠便攜式執行子字串提取任務.

最新教學 更多>
  • 儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    解決PHP 中的POST 請求故障在提供的程式碼片段中:action=''而非:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"檢查$_POST陣列:表單提交後使用 var_dump 檢查 $_POST 陣列的內...
    程式設計 發佈於2024-12-21
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1 和 $array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建...
    程式設計 發佈於2024-12-21
  • 如何使用 PHP 計算兩個日期之間的時差(以秒為單位)?
    如何使用 PHP 計算兩個日期之間的時差(以秒為單位)?
    計算兩個日期之間的時差(以秒為單位)計算兩個日期之間的時差(以秒為單位)在各種情況下都很有用。本文旨在為這項任務提供一個清晰的解決方案,解決先前 Stack Overflow 討論中面臨的挑戰。 確定兩個日期之間的時間跨度,例如“2011-05-12 18:20:20 ”和“2011-05-13 1...
    程式設計 發佈於2024-12-21
  • 插入資料時如何修復「常規錯誤:2006 MySQL 伺服器已消失」?
    插入資料時如何修復「常規錯誤:2006 MySQL 伺服器已消失」?
    插入記錄時如何解決「一般錯誤:2006 MySQL 伺服器已消失」介紹:將資料插入MySQL 資料庫有時會導致錯誤「一般錯誤:2006 MySQL 伺服器已消失」。當與伺服器的連線遺失時會出現此錯誤,通常是由於 MySQL 配置中的兩個變數之一所致。 解決方案:解決此錯誤的關鍵是調整wait_tim...
    程式設計 發佈於2024-12-21
  • 事件冒泡與捕捉:事件傳播模式如何影響 DOM 事件處理?
    事件冒泡與捕捉:事件傳播模式如何影響 DOM 事件處理?
    事件冒泡和捕獲:了解DOM 中的傳播事件冒泡和捕獲在HTML DOM API 中的事件傳播中發揮著至關重要的作用。為了理解它們的功能,讓我們深入研究這兩個概念的複雜性。 事件冒泡與事件捕獲當一個事件發生在嵌套在另一個元素中的元素中時,並且兩個元素都為該特定事件註冊了事件處理程序,事件傳播模式決定了元...
    程式設計 發佈於2024-12-21
  • 如何有效透視 Pandas DataFrame?
    如何有效透視 Pandas DataFrame?
    如何透視資料框? 透視法是一種轉換,它採用具有代表類別的列和代表值的行的資料框,並重新定向它,以便類別位於行中,值位於列中,索引設定為原始行值。 基本文法:df.pivot(index=<row_labels>, columns=<col_labels>, values=&l...
    程式設計 發佈於2024-12-21
  • 最令人煩惱的解析:Timer() - 物件還是函數呼叫?
    最令人煩惱的解析:Timer() - 物件還是函數呼叫?
    最令人煩惱的解析:解開C 11 中的歧義當使用統一初始化器時,C 11 中的“最令人困擾的解析」歧義會出現,如以下程式碼片段所示:#include <iostream> class Timer { public: Timer() {} }; int main() { au...
    程式設計 發佈於2024-12-21
  • 如何使用 Jersey 解決 JAX-RS 中的 CORS 問題?
    如何使用 Jersey 解決 JAX-RS 中的 CORS 問題?
    使用Jersey 透過JAX-RS 處理CORS使用Jersey 透過JAX-RS 處理CORS問題: 您在處理請求時遇到CORS 問題與JAX-RS 和澤西島。具體來說,伺服器未設定必要的CORS 標頭,導致錯誤「請求的資源上不存在'Access-Control-Allow-Origin&...
    程式設計 發佈於2024-12-21
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSocke...
    程式設計 發佈於2024-12-21
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-12-21
  • 如何在頁面載入時從 JSP 呼叫 Servlet 以顯示資料?
    如何在頁面載入時從 JSP 呼叫 Servlet 以顯示資料?
    如何在頁面載入時從JSP 呼叫Servlet在某些情況下,您可能需要從JSP 檔案呼叫Servlet,而無需使用HTML 表單。例如,要在頁面載入時在 HTML 表中顯示資料庫查詢結果。 使用 doGet() 方法的解決方案servlet 中的 doGet() 方法允許請求預處理並重定向到 JSP。...
    程式設計 發佈於2024-12-21
  • 如何自動將 MySQL 表格轉儲到單獨的檔案中?
    如何自動將 MySQL 表格轉儲到單獨的檔案中?
    自動將MySQL 表轉儲到單獨的檔案內建mysqldump 實用程式允許選擇性表轉儲,但需要預先指定表名稱。對於處理新表新增的動態方法,自動化解決方案是必要的。 這樣的解決方案之一是 shell 腳本,它動態查詢資料庫中的所有表名並將每個表轉儲到單獨的壓縮檔案中。這樣就無需在轉儲腳本中手動維護表名。...
    程式設計 發佈於2024-12-21
  • 當更新具有多個進程的大表時,如何解決 MySQL 資料庫中的死鎖?
    當更新具有多個進程的大表時,如何解決 MySQL 資料庫中的死鎖?
    理解MySQL鎖死鎖問題:5,000,000行的MySQL表很容易因為死鎖&&]5,000,000行的MySQL表很容易因為死鎖而發生死鎖並行Perl 進程更新它。更新特定行時會發生死鎖錯誤。 原因:當兩個或多個事務嘗試以衝突的方式取得同一行上的鎖時,就會發生死鎖。在這種情況下,在 file_tab...
    程式設計 發佈於2024-12-21
  • JavaScript 提升中 `let` 和 `const` 與 `var` 有何不同?
    JavaScript 提升中 `let` 和 `const` 與 `var` 有何不同?
    用let 或const 宣告的變數的提升雖然用var 宣告的變數在提升期間的行為符合預期,但用let或const 宣告的變數會表現出來不同的行為。 全部提升聲明所有JavaScript 聲明(var、let、const、function、function*、class)都會進行提升,這意味著它們在各...
    程式設計 發佈於2024-12-21
  • 如何在 Go 中將巢狀 JSON 解組到物件數組中?
    如何在 Go 中將巢狀 JSON 解組到物件數組中?
    將嵌套 JSON 解組到 Go 中的物件陣列中問題考慮以下 JSON 資料:{ "1001":{ "level":10, "monster-id":1001, "skill-level&q...
    程式設計 發佈於2024-12-21

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3