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 で LastIndexOf 機能をシミュレートするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。