Operasi rentetan SQL Server: cekap mencari kejadian terakhir aksara
Mengakses indeks terakhir subrentetan adalah penting dalam pelbagai operasi pangkalan data. Walaupun SQL Server tidak mempunyai fungsi LastIndexOf
langsung, terdapat beberapa cara bijak untuk mencapai fungsi ini.
Penyelesaian yang biasa dilakukan ialah membalikkan rentetan dan menggunakan CHARINDEX
untuk mencari kejadian terakhir aksara. Walau bagaimanapun, pendekatan ini boleh menyusahkan dan kurang boleh dibaca.
Nasib baik, SQL Server 2016 memperkenalkan beberapa fungsi baharu yang memudahkan tugas ini:
Dapatkan subrentetan selepas kejadian terakhir aksara:
Untuk mendapatkan subrentetan selepas kejadian terakhir aksara, anda boleh menggunakan formula berikut:
<code class="language-sql">select right(db_name(), charindex('_', reverse(db_name()) + '_') - 1)</code>
Ungkapan ini mula-mula membalikkan rentetan dan kemudian menggunakan CHARINDEX
untuk mencari aksara terakhir. Kemudian, ia menggunakan fungsi RIGHT
untuk mengekstrak subrentetan.
Dapatkan subrentetan sebelum kejadian terakhir aksara:
Sebagai alternatif, jika anda mahukan subrentetan sebelum kejadian terakhir aksara, anda boleh menggunakan sintaks berikut:
<code class="language-sql">select left(db_name(), len(db_name()) - charindex('_', reverse(db_name()) + '_'))</code>
Di sini, fungsi LEN
menentukan jumlah panjang rentetan manakala fungsi LEFT
digunakan untuk mengekstrak subrentetan yang diperlukan.
Dengan menggunakan teknik ini, anda boleh memanipulasi rentetan dalam SQL Server 2016 dengan lebih cekap, menjadikan operasi kompleks lebih mudah dan lebih mudah dibaca.
Atas ialah kandungan terperinci Bagaimana untuk Mencari Kejadian Terakhir Watak dalam Pelayan SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!