Penjelasan terperinci tentang awalan 'N' dalam literal rentetan T-SQL
Dalam pertanyaan T-SQL, anda mungkin menghadapi situasi di mana anda menggunakan awalan 'N' sebelum memasukkan nilai rentetan ke dalam jadual. Perwakilan bukan intuitif ini mempunyai tujuan khusus dan penting untuk memahami kepentingannya.
Peranan awalan 'N'
Awalan 'N' menunjukkan bahawa rentetan yang akan dimasukkan adalah dalam format Unicode, khususnya jenis data nchar, nvarchar atau ntext. Jenis data ini menyimpan data aksara menggunakan pengekodan aksara yang konsisten, tanpa mengira set aksara lalai pangkalan data.
Bila hendak menggunakan 'N'
Menggunakan awalan 'N' adalah kritikal apabila anda memasukkan rentetan yang mengandungi aksara bukan ASCII, seperti huruf asing atau simbol khas. Ini memastikan bahawa rentetan disimpan dengan betul dan boleh diambil semula tanpa kerosakan data.
Sebagai contoh, dalam pertanyaan yang disediakan:
<code class="language-sql">INSERT INTO Personnel.Employees VALUES(N'29730', N'Philippe', N'Horsford', 20.05, 1);</code>
'Philippe' Untuk aksara beraksen Perancis dalam nama, awalan 'N' memastikan bahawa data disimpan dalam format Unicode, membenarkan perwakilan yang betul bagi aksara ini.
Kepentingan Data Unikod
Menggunakan data Unicode adalah penting kerana ia membenarkan keserasian merentas platform dan memastikan perwakilan aksara yang konsisten merentas sistem dan bahasa yang berbeza. Dengan menambahkan 'N' pada rentetan, anda boleh mengelakkan kehilangan data atau rasuah akibat perbezaan dalam pengekodan aksara.
Alternatif kepada awalan 'N'
Dalam sesetengah kes, anda boleh menggunakan klausa COLLATE untuk menentukan set aksara khusus untuk literal rentetan. Ini berguna jika anda ingin menukar rentetan kepada pengekodan tertentu sebelum memasukkan.
Contoh:
<code class="language-sql">INSERT INTO Personnel.Employees VALUES('29730', COLLATE Latin1_General_CI_AS 'Philippe', COLLATE Latin1_General_CI_AS 'Horsford', 20.05, 1);</code>
Atas ialah kandungan terperinci Mengapa Menggunakan Awalan 'N' dalam T-SQL String Literals?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!