Различия между Varchar и Nvarchar

Anonim

Varchar vs Nvarchar

Varchar - короткое имя для Variable Character Field. Символы представляют данные с неопределенной длиной. Varchar в действительности представляет собой тип столбца данных, который находится в системах управления базами данных. Размер поля столбцов Varchar может варьироваться в зависимости от рассматриваемой базы данных.

В Oracle 9i поле имеет максимальный предел 4000 символов. MySQL имеет предел данных 65535 для строки, а сервер Microsoft SQL Server 2005 имеет ограничение поля 8000. Эта цифра может увеличиться на сервере Microsoft SQL при использовании Varchar (max), увеличиваясь до 2 гигабайт. С другой стороны, Nvarchar - это столбец, который может хранить любую длину данных Unicode. Кодовая страница, которой должен придерживаться Nvarchar, - это 8-битное кодирование. Максимальный размер для Varchar составляет 8000, а максимальный размер для NVarchar - 4000. Это фактически означает, что один столбец Varchar может содержать максимум 8000 символов, а один столбец Nvarchar может составлять не более 4000 символов. Превышение значений столбцов становится огромной проблемой и может даже вызвать серьезные проблемы, поскольку строки не могут охватывать несколько страниц, за исключением SQL Server 2005, и ограничение должно быть соблюдено, или будут возникать ошибки или усечение.

Одним из главных отличий между Varchar и Nvarchar является использование меньшего пространства в Varchar. Это связано с тем, что Nvarchar использует Unicode, который, из-за хлопот кодирования специфики, занимает больше места. Для каждого сохраненного символа Unicode требует двух байтов данных, и именно это может привести к тому, что значение данных будет выглядеть выше по сравнению с данными, отличными от Unicode, которые использует Varchar. Varchar, с другой стороны, требует только одного байта данных для каждого сохраненного символа. Однако, что более важно, хотя использование Unicode занимает больше места, оно решает проблемы, возникающие из-за несовместимости кодовых страниц, которые могут быть решены вручную.

Таким образом, возможность пространства можно упускать из виду, поскольку для сокращения времени, требуемого Unicode, требуется исправление возникающих несовместимостей. Кроме того, стоимость дисков и памяти также стала довольно доступной, гарантируя, что функция пространства часто может быть упущена, а более длительное время, которое требуется для решения возникающих проблем с Varchar, не может быть легко устранено.

На всех платформах разработки используются современные операционные системы, что позволяет запускать Unicode. Это означает, что Nvarchar используется чаще, чем Varchar. Кодирование конверсий исключается, сокращая время, необходимое для чтения и записи в базу данных. Это также значительно уменьшает количество ошибок, и восстановление ошибок преобразования, которые происходят, становится простой проблемой для решения.

Преимущество использования Unicode также применимо к людям, использующим интерфейсы приложений ASCII, поскольку база данных хорошо реагирует, в частности, алгоритмы операционной системы и базы данных. Данные Unicode позволяют избежать проблем, связанных с преобразованием, и данные всегда могут быть проверены, если они ограничены 7-разрядным ASCII, независимо от устаревшей системы, которая должна поддерживаться.

Резюме

Varchar и Nvarchar имеют разные типы символов. Varchar использует данные, отличные от Unicode, в то время как Nvarchar использует данные Unicode.

Оба Varchar и Nvarchar имеют разные типы данных, которые должны соблюдаться. Varchar сохраняет данные только в 1 байтовой последовательности, а Nvarchar сохраняет данные в 2 байта для каждого символа

Максимальная длина также изменяется. Длина Varchar ограничена 8000 байтами, а 4000 байтов - предел для Nvarchar.

Это связано с тем, что размер хранилища в Varchar более прост в сравнении с данными Unicode, используемыми Nvarchar.