Когато казвате, че датите ще бъдат уникални, имате предвид, че мислите ще бъдат уникални или уникалността им е гарантирана от постановката на проблема? Според моя опит някои неща се оказват доста по-малко уникални, отколкото си представяте (пример са номерата на социалното осигуряване в САЩ).
Ако стойностите на датата не са гарантирани уникални, трябва да добавите целочислен ключ.
Ако стойностите на датата са гарантирано уникални, променят ли се? Ако се променят, реферират ли се от други таблици? Ако и двата отговора са "да", вероятно трябва да добавите целочислен ключ.
Ако стойностите на датата са гарантирано уникални и не се променят или не са посочени, можете да ги използвате за ключа. Редовните DATETIME са 8 байта, а стандартните INTEGER стойности са 4 байта, което може да има малък ефект върху индексирането. Ако вашите стойности за дата са само дати или само точни до минута или по-малко и в по-ограничения диапазон, разрешен от типа, можете да използвате SMALLDATETIME и да намалите стойностите на тези индекси до 4 байта.