Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Menghantar Rentetan NVARCHAR dengan Selamat kepada Integer dalam T-SQL, Mengendalikan Nilai Bukan Angka?

Bagaimanakah Saya Boleh Menghantar Rentetan NVARCHAR dengan Selamat kepada Integer dalam T-SQL, Mengendalikan Nilai Bukan Angka?

DDD
DDDasal
2024-12-28 08:12:13623semak imbas

How Can I Safely Cast NVARCHAR Strings to Integers in T-SQL, Handling Non-Numeric Values?

Penukaran T-SQL: Menghantar Rentetan kepada Integer dengan Nilai Lalai atau Pengendalian NULL

Dalam T-SQL, menukar rentetan nvarchar kepada integer adalah penting untuk manipulasi data. Walau bagaimanapun, apabila menemui aksara bukan angka, penukaran tersebut boleh gagal. Ini menimbulkan keperluan untuk mengendalikan ralat penukaran dengan anggun.

Penyelesaian

Ekspresi CASE WHEN menyediakan mekanisme yang teguh untuk mengendalikan senario ini. Sintaksnya adalah seperti berikut:

CASE WHEN ISNUMERIC(@text) = 1 THEN CAST(@text AS INT) ELSE NULL END

Begini cara ia berfungsi:

  • ISNUMERIC(): Fungsi ini menilai sama ada rentetan nvarchar @text mewakili nilai angka yang sah. Jika ia mengembalikan 1 (true), rentetan itu ialah angka.
  • CAST(): Jika ISNUMERIC() mengembalikan true, rentetan dibuang ke integer menggunakan CAST(). Jika tidak, hasilnya ditetapkan kepada NULL.

Pendekatan ini memastikan bahawa jika penukaran daripada rentetan kepada integer berjaya, nilai integer yang betul dikembalikan. Walau bagaimanapun, jika penukaran gagal disebabkan oleh aksara bukan angka, nilai NULL dikembalikan.

Kod Contoh

DECLARE @text AS NVARCHAR(10)

-- Numeric string
SET @text = '100'
SELECT @text, CASE WHEN ISNUMERIC(@text) = 1 THEN CAST(@text AS INT) ELSE NULL END

-- Non-numeric string
SET @text = 'XXX'
SELECT @text, CASE WHEN ISNUMERIC(@text) = 1 THEN CAST(@text AS INT) ELSE NULL END

Had

Sementara fungsi ISNUMERIC() menawarkan cara yang mudah untuk menyemak nilai berangka, adalah penting untuk mengetahuinya had:

  • Ia kembali benar untuk rentetan yang mengandungi simbol mata wang ($), pemisah perpuluhan (,), ribuan pemisah (.), dan tanda aritmetik ( dan -).
  • Ia tidak membezakan antara integer dan jenis data berangka lain, seperti perpuluhan.

Walaupun pengehadan ini, CASE WHEN dengan ISNUMERIC() dan CAST() menyediakan penyelesaian praktikal untuk menghantar rentetan kepada integer dan mengendalikan kes bukan angka dalam T-SQL.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menghantar Rentetan NVARCHAR dengan Selamat kepada Integer dalam T-SQL, Mengendalikan Nilai Bukan Angka?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn