ホームページ > データベース > mysql チュートリアル > SQL Server で LastIndexOf 機能をシミュレートするにはどうすればよいですか?

SQL Server で LastIndexOf 機能をシミュレートするにはどうすればよいですか?

DDD
リリース: 2025-01-12 12:56:42
オリジナル
228 人が閲覧しました

How to Simulate LastIndexOf Functionality in SQL Server?

SQL Server の LastIndexOf 関数をモックする

SQL Server 自体は、プログラミング言語で一般的に使用される LastIndexOf 関数と同等のものを直接提供しません。ただし、文字列内で最後に出現した部分文字列を見つける方法は他にもあります。

CHARINDEX 関数と REVERSE 関数を使用する

1 つの方法は、CHARINDEX 関数と REVERSE 関数を一緒に使用することです。質問で提供されているコードに示されているように、このアプローチは長くて面倒になる可能性があります:

<code class="language-sql">SELECT REVERSE(SUBSTRING(REVERSE(DB_NAME()), 1,
    CHARINDEX('_', REVERSE(DB_NAME()), 1) - 1))</code>
ログイン後にコピー

RIGHT 関数と REVERSE 関数を使用する

より効率的で読みやすいソリューションを実現するには、RIGHT 関数と REVERSE 関数を組み合わせます。このメソッドを使用すると、次のように、指定された文字が最後に出現した後の部分文字列を取得できます。

<code class="language-sql">select right(db_name(), charindex('_', reverse(db_name()) + '_') - 1)</code>
ログイン後にコピー

LEFT 関数と REVERSE 関数を使用する

同様に、最後に出現する前の部分文字列を取得するには、LEFT 関数を使用できます。

<code class="language-sql">select left(db_name(), len(db_name()) - charindex('_', reverse(db_name()) + '_'))</code>
ログイン後にコピー
これらの手法を使用すると、SQL Server で最後のインデックス操作を効率的に実行でき、元のアプローチよりも直感的で効率的な代替手段が提供されます。

以上がSQL Server で LastIndexOf 機能をシミュレートするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート