SQL Server - это база данных, ориентированная на строки. Это в отличие от базы данных, ориентированной на столбцы. Это означает, что в SQL Server все данные для данной строки хранятся вместе на диске. Давайте рассмотрим пример:
Допустим, у вас есть таблица Customer с 3 столбцами: FirstName, MiddleInitial и LastName. Затем, скажем, у вас есть 3 записи в этой таблице для Джаббы Т. Хатта, Денниса Т. Менаса и Джорджа Буша-младшего.
В базе данных, ориентированной на строки (например, SQL Server), записи будут храниться на диске следующим образом:
Джабба, Т, Хатт; Деннис, T, Menace; Джордж, W, Буш;
Напротив, база данных, ориентированная на столбцы, будет хранить записи на диске следующим образом:
Джабба, Деннис, Джордж; Т, Т, Ш; Угроза Хатта, Буш;
Где столбцы сгруппированы вместо строк.
Теперь, когда вы собираетесь добавить столбец в таблицу в базе данных, ориентированной на строки (например, SQL Server), новые данные для каждого столбца должны быть вставлены рядом с существующими строками, сдвигая строки, требующие большого количества операции чтения / записи. Итак, если бы вы вставили новый столбец для префикса клиента, который по умолчанию равен «Mr», вы получите следующее:
Мистер Джабба, Т, Хатт; Мистер Деннис, T, Menace; Мистер Джордж, W, Буш;
Как видите, все исходные данные смещены вправо. С другой стороны, когда вы вставляете новый столбец со значением по умолчанию NULL, новые данные не должны быть помещены в существующие строки. Таким образом, происходит меньшее смещение, требующее меньше операций чтения / записи на диск.
Конечно, это упрощение того, что на самом деле происходит на диске. Есть и другие вещи, которые необходимо учитывать при работе с индексами, страницами и т. Д. Но это должно помочь вам получить представление.
Для пояснения Я вовсе не предлагаю вам перейти на базу данных, ориентированную на столбцы, я просто поместил эту информацию туда, чтобы помочь объяснить, что означают строки, ориентированные.