Condividi tramite


Operatori dei costruttori di tipo (Entity SQL)

In Entity SQL sono disponibili tre tipi di costruttori, ovvero costruttori di riga, costruttori di tipi denominati e costruttori di insiemi.

Costruttori di riga

I costruttori di riga vengono utilizzati in Entity SQL per costruire record anonimi e con strutture tipizzate da uno o più valori. Il tipo di risultato di un costruttore di riga è un tipo di riga i cui tipi di campo corrispondono ai tipi dei valori utilizzati per costruire la riga. L'espressione seguente consente ad esempio di costruire un valore di tipo Record(a int, b string, c int):

ROW(1 AS a, "abc" AS b, a + 34 AS c)

Se non si fornisce un alias per un'espressione in un costruttore di riga, in Entity Framework viene eseguito un tentativo di generarne uno. Per ulteriori informazioni, vedere la sezione "Regole relative all'utilizzo degli alias" in Identificatori (Entity SQL).

Le regole seguenti riguardano l'utilizzo di alias nelle espressioni in un costruttore di riga:

  • Le espressioni in un costruttore ROW non possono fare riferimento ad altri alias nello stesso costruttore.

  • Due espressioni nello stesso costruttore di riga non possono avere lo stesso alias.

Per ulteriori informazioni sui costruttori di riga, vedere ROW (Entity SQL).

Costruttori di insiemi

I costruttori di insiemi vengono utilizzati in Entity SQL per creare un'istanza di un multiset da un elenco di valori. Tutti i valori nel costruttore devono essere di tipo T reciprocamente compatibile e il costruttore produce un insieme di tipo Multiset<T>. L'espressione seguente consente ad esempio di creare un insieme di valori interi:

Multiset(1, 2, 3)

{1, 2, 3}

I costruttori multiset vuoti non sono supportati perché non è possibile determinare il tipo degli elementi. Il codice seguente non è valido:

multiset() {}

Per ulteriori informazioni, vedere MULTISET (Entity SQL).

Costruttori di tipi denominati (inizializzatori NamedType)

In Entity SQL i costruttori di tipi (inizializzatori) possono creare istanze di tipi di entità e di tipi complessi denominati. L'espressione seguente consente ad esempio di creare un'istanza di un tipo Person.

Person("abc", 12)

L'espressione seguente consente di creare un'istanza di un tipo complesso.

MyModel.ZipCode(‘98118’, ‘4567’)

L'espressione seguente consente di creare un'istanza di un tipo complesso nidificato.

MyModel.AddressInfo('My street address', 'Seattle', 'WA', MyModel.ZipCode('98118', '4567'))

L'espressione seguente consente di creare un'istanza di un'entità con un tipo complesso nidificato.

MyModel.Person("Bill", MyModel.AddressInfo('My street address', 'Seattle', 'WA', MyModel.ZipCode('98118', '4567')))

Nell'esempio seguente viene illustrato come inizializzare una proprietà di un tipo complesso impostandola su Null. MyModel.ZipCode(‘98118’, null)

Si suppone che gli argomenti del costruttore si trovino nello stesso ordine della dichiarazione degli attributi del tipo.

Per ulteriori informazioni, vedere Costruttore di tipi denominati (Entity SQL).

Vedere anche

Concetti

Riferimenti a Entity SQL
Panoramica su Entity SQL
Type System (Entity SQL)