Salah satu contoh di mana hal ini dapat membuat perbedaan adalah dapat mencegah pengoptimalan kinerja yang menghindari penambahan informasi pembuatan versi baris ke tabel dengan pemicu setelahnya.
Ini tercakup dalam SQL Kiwi di sini
Ukuran sebenarnya dari data yang disimpan tidak material - yang penting adalah ukuran potensial.
Demikian pula jika menggunakan tabel yang dioptimalkan memori sejak 2016, dimungkinkan untuk menggunakan kolom LOB atau kombinasi lebar kolom yang berpotensi melebihi batas inrow tetapi dengan penalti.
(Maks) kolom selalu disimpan di luar baris. Untuk kolom lain, jika ukuran baris data dalam definisi tabel dapat melebihi 8.060 byte, SQL Server mendorong kolom dengan panjang variabel terbesar di luar baris. Sekali lagi, ini tidak tergantung pada jumlah data yang Anda simpan di sana.
Ini dapat berdampak negatif besar pada konsumsi dan kinerja memori
Kasus lain di mana mendeklarasikan lebar kolom dapat membuat perbedaan besar adalah jika tabel akan diproses menggunakan SSIS. Memori yang dialokasikan untuk kolom panjang variabel (non BLOB) ditetapkan untuk setiap baris dalam pohon eksekusi dan sesuai dengan panjang maksimum yang dinyatakan kolom yang dapat menyebabkan penggunaan buffer memori yang tidak efisien (contoh) . Sementara pengembang paket SSIS dapat menyatakan ukuran kolom yang lebih kecil daripada sumbernya, analisis ini paling baik dilakukan di awal dan diterapkan di sana.
Kembali ke mesin SQL Server itu sendiri kasus serupa adalah ketika menghitung hibah memori untuk mengalokasikan untuk SORT
operasi SQL Server mengasumsikan bahwa varchar(x)
kolom rata-rata akan mengkonsumsi x/2
byte.
Jika sebagian besar varchar
kolom Anda lebih penuh dari itu, ini dapat menyebabkan sort
operasi tumpah tempdb
.
Dalam kasus Anda, jika varchar
kolom Anda dideklarasikan sebagai 8000
byte tetapi sebenarnya memiliki konten yang jauh lebih sedikit dari itu, kueri Anda akan dialokasikan memori yang tidak diperlukan yang jelas tidak efisien dan dapat menyebabkan menunggu pemberian memori.
Ini tercakup dalam Bagian 2 dari SQL Workshops Webcast 1 yang dapat diunduh dari sini atau lihat di bawah.
use tempdb;
CREATE TABLE T(
id INT IDENTITY(1,1) PRIMARY KEY,
number int,
name8000 VARCHAR(8000),
name500 VARCHAR(500))
INSERT INTO T
(number,name8000,name500)
SELECT number, name, name
FROM master..spt_values
SELECT id,name500
FROM T
ORDER BY number
SELECT id,name8000
FROM T
ORDER BY number