In ultimele zile am început sa lucrez cu Fluent NHibernate si am descoperit GuidComb. M-am documentat sa vad ce înseamna de fapt. Pe scurt:
Din cei 32 de biti pe care un guid ii conține, 16 sunt generați in funcție de configurația hardware a mașinii( începînd cu Windows 2000, seria plăcii de rețea nu se mai folosește).
Iar următorii 16 sunt generați in forma următoare:
In general se cîștiga un spor de performanta de 25%-30% pe tabele care conține PK ca și guid.In cazul in care tabela pe care lucrați nu are PK, sporul de performanta poate sa fie 0% sau chiar negativ in unele situații. Pentru mai multe informații despre sporul de performanta puteti sa gasiti aici.
PS: Cînd ne ajuta un Guid? Un exemplu este cînd se lucrează cu o aplicația și offline, caz in care la sincronizare nu mai este nevoie de regenerare de PK.
One of the better alternatives that i kinda like is the guid.comb strategy. Using regular guids as a primary key value leads to fragmented indexes (due to the randomness of the guid’s value) which leads to bad performance. This is a problem that the guid.comb strategy can solve quite easily for you.Nu are rost sa traduc și să explic din nou acelasi lucru. O să găsiți pe Google destule materiale. Partea interesanta este modul in care se generează aceste guiduri.
Din cei 32 de biti pe care un guid ii conține, 16 sunt generați in funcție de configurația hardware a mașinii( începînd cu Windows 2000, seria plăcii de rețea nu se mai folosește).
Iar următorii 16 sunt generați in forma următoare:
- 0-9: se generează pe baza unui uniqueidentifier( depinde de framework);
- 10-15: pe baza la Datetime;
In general se cîștiga un spor de performanta de 25%-30% pe tabele care conține PK ca și guid.In cazul in care tabela pe care lucrați nu are PK, sporul de performanta poate sa fie 0% sau chiar negativ in unele situații. Pentru mai multe informații despre sporul de performanta puteti sa gasiti aici.
PS: Cînd ne ajuta un Guid? Un exemplu este cînd se lucrează cu o aplicația și offline, caz in care la sincronizare nu mai este nevoie de regenerare de PK.
Se pare ca pierderea de performanta e numai daca acel PK are un clustered index, altfel nu.
ReplyDelete