MySQL SUBSTRING_INDEX

Haider Ali 2023年6月20日
MySQL SUBSTRING_INDEX

このガイドでは、MySQL の substring_index 関数の概念を理解します。 このような概念により、ユーザーはさまざまな文字列の配列から選択した文字列を取得できます。

この機能について詳しく見ていきましょう。

MySQL のSUBSTRING_INDEX

まず、substring_index 関数を操作するために不可欠ないくつかの重要な概念を理解しましょう。 具体的には、DELIMITERCHARINDEX() です。

Delimiter は、文字列を分割する主なポイントとして機能する複合記号です。 文字列はその時点で壊れ、フェッチされた文字列は、入力に応じて、その時点より前または前のいずれかになります。

Charindex() は MySQL の関数で、文字列内の特定の部分文字列の位置をフェッチしてその位置を返したいときに使用されます。 パラメータには (substring, string) が含まれます。

Substring 関数コード

次のコードは、Substring_index 関数の動作を示しています。 このコードは、MySQL の substring_index 関数に相当する SQL Server です。

次のコードは、SQL Server で実行する必要があります。

CREATE FUNCTION SUB_STRING
(
@STRING VARCHAR(8000),
@DELIMITER VARCHAR(1),
@POSITION INT
)
RETURNS VARCHAR(8000)
AS
BEGIN
IF @POSITION = 0
BEGIN
	RETURN SUBSTRING(@STRING,0,CHARINDEX(@DELIMITER,@STRING))
END
IF @POSITION = 1
BEGIN
	RETURN SUBSTRING(@STRING,CHARINDEX(@DELIMITER,@STRING)+1,LEN(@STRING))
END
RETURN @STRING
END;

コードを理解しましょう。

SUB_STRING という関数を作成しました。この関数内には、パラメーター @string (部分文字列が取得される文字列)、@delimiter および @position (2つの値 0 または 1 があります) があります。 )。

@Position は、0 に設定すると文字列の開始インデックスから区切りポイントまでフェッチを開始し、1 に設定すると 1 ポイント先からフェッチを開始するパラメータです。 区切り点から文字列の最後まで。

Begin 句はコード ブロックの開始を示し、End 句はコード ブロックの終了を示します。

最初の IF 条件では、位置は 0 に設定されます。 substring 関数では、Charindex() 関数で 0 インデックスから取得する文字列を取得しました。

これにより、0 インデックスから区切り点までの部分文字列が返されます。

例 1

次の例でこれを理解してください。

SELECT dbo.SUB_STRING('ahsanali@email.com','@',0)

部分文字列 0

ご覧のとおり、0 インデックスから区切り点までの部分文字列が返されました。

2 番目の IF 条件は、位置を 1 に設定します。 部分文字列関数では、部分文字列をフェッチする +1 条件を持つ Charindex() 関数を取得しました。これは、区切り点の前の 1 インデックスで、文字列の最後までです。

例 2

別の例を使ってさらに理解しましょう。

SELECT dbo.SUB_STRING('ahsanali@email.com','@',1)

部分文字列 1

ご覧のとおり、区切り点の前のインデックス 1 で最後の文字列までの部分文字列が返されました。

また、もう 1つのポイントは、@position (0 または 1) で間違った値を指定すると、完全な文字列が返されることです。

SELECT dbo.SUB_STRING('ahsanali@email.com','&',3)

間違った値

著者: Haider Ali
Haider Ali avatar Haider Ali avatar

Haider specializes in technical writing. He has a solid background in computer science that allows him to create engaging, original, and compelling technical tutorials. In his free time, he enjoys adding new skills to his repertoire and watching Netflix.

LinkedIn