MySQL veritabanında CHAR ve VARCHAR gibi iki ana veri türü bulunmaktadır. Her iki veri türü de bir metin verisini saklamak için kullanılır fakat aralarında bazı farklar vardır.
CHAR veri türü, sabit boyutlu bir metin verisini saklanması için kullanılır. Veri boyutu, veritabanı şemasında belirtilir. CHAR veri tipi, veri depolaması sırasında belirtilen boyutta bir alan tahsis eder ve bu boyuttan küçük bir veri saklansa dahi, belirtilen boyut kadar yer kaplar. Örneğin; bir CHAR(10) alanına 5 karakterlik bir metin değeri saklanırsa, veri tabanının hafızasında tam 10 karakterlik bir alana sahip olur. Bu özellik, alan boyutları farklı olmayan birleştirme işlemlerinde önemlidir.
VARCHAR veri türü ise, değişken boyutlu bir metin verisini saklamaya yöneliktir. Bu veri türünde, veri boyutu belirtilirken, veri alanının tam boyutu saklanmaz ve veritabanı, yalnızca saklanan veri boyutu kadar bir alan tahsis eder. Örneğin; bir VARCHAR(10) alanına 5 karakterlik bir metin değeri saklanırsa, veri tabanında sadece 5 karakterlik bir alan kaplamaktadır.
CHAR ve VARCHAR arasındaki en belirgin fark, veri boyutu ve kullanılan alan miktarıdır. CHAR veri tipi, her zaman belirtilen boyutta bir alan tahsis ederken VARCHAR veri tipi, gerçek veri boyutuna göre alan tahsis eder.
Aşağıdaki örneklerde, CHAR ve VARCHAR veri türleri arasındaki farkı açıklamak için sadece bir karakter dizisi saklanacak olan bir tablo oluşturulmuştur:
```sql
CREATE TABLE example (
id INT AUTO_INCREMENT PRIMARY KEY,
char_column CHAR(10),
varchar_column VARCHAR(10)
);
```
Yukarıdaki örnekte, `char_column` ve `varchar_column` adlarında iki ayrı sütun oluşturuldu. `char_column` sütunu, 10 karakter uzunluğunda bir alan tahsis etmektedir. `varchar_column` sütunu ise sadece 10-bytelik bir alan tahsis edilmektedir.
```sql
INSERT INTO example (char_column, varchar_column) VALUES ('test', 'test');
```
Yukarıdaki komut, tabloya bir satır ekler. `'test'` karakter dizisi hem `char_column` hem de `varchar_column` sütunlarına eklendi. Bu durumda, `char_column` sütunu, boşlukları dahil 10 karakter uzunluğunda bir alan kaplamaktadır. Ancak, `varchar_column` sütunu yalnızca 4 karakterlik bir alan kaplamaktadır.
```sql
INSERT INTO example (char_column, varchar_column) VALUES ('testing', 'testing');
```
Yukarıdaki komut, aynı karakter dizileri, içinde bir karakter eklendi şeklinde tekrar gönderildi. Bu durumda, `char_column` sütunu hala boşlukları dahil tam 10 karakter uzunluğundadır. Ancak, `varchar_column` sütunu, 7 karakterlik bir alan kaplamaktadır.
CHAR ve VARCHAR arasındaki farkın özetle anlatıldığı bu örnekler, veritabanı uygulayıcılarına, hangi veri türünün hangi durumlarda kullanılması gerektiği konusunda bir fikir verebilir.