Oracle
 sql >> база данни >  >> RDS >> Oracle

Разлика между VARCHAR2(10 CHAR) и NVARCHAR2(10)

Типът данни NVARCHAR2 е въведен от Oracle за бази данни, които искат да използват Unicode за някои колони, като същевременно запазват друг набор от знаци за останалата част от базата данни (която използва VARCHAR2). NVARCHAR2 е тип данни само за Unicode.

Една от причините, поради които може да искате да използвате NVARCHAR2, може да е, че вашата DB използва набор от символи, различен от Unicode, и все пак искате да можете да съхранявате Unicode данни за някои колони, без да променяте основния набор от знаци. Друга причина може да е, че искате да използвате два набора символи Unicode (AL32UTF8 за данни, които идват предимно от Западна Европа, AL16UTF16 за данни, които идват предимно от Азия например), тъй като различните набори от знаци няма да съхраняват едни и същи данни еднакво ефективно.

И двете колони във вашия пример (Unicode VARCHAR2(10 CHAR) и NVARCHAR2(10) ) ще може да съхранява същите данни, но съхранението на байтове ще бъде различно. Някои низове може да се съхраняват по-ефективно в едната или другата.

Имайте предвид също, че някои функции няма да работят с NVARCHAR2, вижте този въпрос SO:

  • Oracle Text няма да работи с NVARCHAR2. Какво друго може да не е налично?


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Въпроси за Oracle DBA в реално време

  2. Времето за изчакване за метода OracleDataReader.Read

  3. Обръщане на данни с помощта на две колони

  4. Как да разберете дали дадена стойност съществува в рамките на VARRAY

  5. Оптимизаторът в Oracle Database 19c