Condividi tramite


SQLColumns

SQLColumnsrestituisce SQL_SUCCESS se esistono o meno valori per i parametri CatalogName, TableName o ColumnName. SQLFetch restituisce SQL_NO_DATA quando i valori non validi vengono usati in questi parametri.

Nota

Per i tipi di valori di grandi dimensioni, tutti i parametri della lunghezza verranno restituiti con un valore di SQL_SS_LENGTH_UNLIMITED.

SQLColumns può essere eseguito in un cursore del server statico. Un tentativo di eseguire SQLColumns in un cursore aggiornabile (dinamico o keyset) restituirà SQL_SUCCESS_WITH_INFO, che indica che il tipo di cursore è stato modificato.

Il driver ODBC SQL Server Native Client supporta la creazione di report per le tabelle nei server collegati accettando un nome a due parti per il parametro CatalogName: Linked_Server_Name.Catalog_Name.

Per ODBC 2. Le applicazioni x non usano caratteri jolly in TableName, SQLColumns restituisce informazioni su tutte le tabelle i cui nomi corrispondono a TableName e sono di proprietà dell'utente corrente. Se l'utente corrente non possiede alcuna tabella il cui nome corrisponde al parametro TableName , SQLColumns restituisce informazioni sulle tabelle di proprietà di altri utenti in cui il nome della tabella corrisponde al parametro TableName . Per ODBC 2. x applicazioni che usano caratteri jolly, SQLColumns restituisce tutte le tabelle i cui nomi corrispondono a TableName. Per ODBC 3. Le applicazioni SQLColumns x restituiscono tutte le tabelle i cui nomi corrispondono a TableName indipendentemente dal proprietario o dal fatto che vengano usati caratteri jolly.

Nella tabella seguente vengono elencate le colonne restituite dal set di risultati:

Nome colonna Descrizione
DATA_TYPE Restituisce SQL_VARCHAR, SQL_VARBINARY o SQL_WVARCHAR per i tipi di dati varchar(max).
TYPE_NAME Restituisce "varchar", "varbinary" o "nvarchar" per i tipi di dati varchar(max), varbinary(max)e nvarchar(max).
COLUMN_SIZE Restituisce SQL_SS_LENGTH_UNLIMITED per i tipi di dati varchar(max) che indicano che le dimensioni della colonna sono illimitate.
BUFFER_LENGTH Restituisce SQL_SS_LENGTH_UNLIMITED per i tipi di dati varchar(max) che indicano che le dimensioni del buffer sono illimitate.
SQL_DATA_TYPE Restituisce SQL_VARCHAR, SQL_VARBINARY o SQL_WVARCHAR per i tipi di dati varchar(max).
CHAR_OCTET_LENGTH Restituisce la lunghezza massima di una colonna di tipo carattere o binario. Restituisce 0 per indicare che la dimensione è illimitata.
SS_XML_SCHEMACOLLECTION_CATALOG_NAME Restituisce il nome del catalogo nel quale è definito il nome di una raccolta di XML Schema. Se non è possibile trovare il nome del catalogo, questa variabile contiene una stringa vuota.
SS_XML_SCHEMACOLLECTION_SCHEMA_NAME Restituisce il nome dello schema nel quale è definito il nome di una raccolta di XML Schema. Se non è possibile trovare il nome dello schema, questa variabile contiene una stringa vuota.
SS_XML_SCHEMACOLLECTION_NAME Restituisce il nome di una raccolta di XML Schema. Se non è possibile trovare il nome, questa variabile contiene una stringa vuota.
SS_UDT_CATALOG_NAME Nome del catalogo contenente il tipo definito dall'utente.
SS_UDT_SCHEMA_NAME Nome dello schema contenente il tipo definito dall'utente.
SS_UDT_ASSEMBLY_TYPE_NAME Nome completo dell'assembly del tipo definito dall'utente.

Per le UDT, la colonna TYPE_NAME esistente viene usata per indicare il nome dell'UDT; pertanto non deve essere aggiunta alcuna colonna aggiuntiva al set di risultati di SQLColumns o SQLProcedureColumns. DATA_TYPE per un parametro o una colonna con tipo definito dall'utente è SQL_SS_UDT.

Per il tipo definito dall'utente dei parametri, è possibile utilizzare i nuovi descrittori specifici del driver definiti precedentemente per ottenere o impostare le proprietà di metadati aggiuntive di un tipo definito dall'utente, nel caso in cui il server restituisca o richieda queste informazioni.

Quando un client si connette a SQL Server e chiama SQLColumns, usando valori NULL o jolly per il parametro di input del catalogo non restituirà informazioni da altri cataloghi. Verranno invece restituite solo informazioni relative al catalogo corrente. Il client può prima chiamare SQLTables per determinare in quale catalogo si trova la tabella desiderata. Il client può quindi usare tale valore del catalogo per il parametro di input del catalogo nella chiamata a SQLColumns per recuperare informazioni sulle colonne di tale tabella.

SQLColumns e parametri con valori di tabella

Il set di risultati restituito da SQLColumns dipende dall'impostazione di SQL_SOPT_SS_NAME_SCOPE. Per altre informazioni, vedere SQLSetStmtAttr. Di seguito sono indicate le colonne che sono state aggiunte per i parametri con valori di tabella:

Nome colonna Tipo di dati Contenuto
SS_IS_COMPUTED Smallint Per una colonna in TABLE_TYPE, SQL_TRUE se la colonna è una colonna calcolata. In caso contrario, SQL_FALSE.
SS_IS_IDENTITY Smallint SQL_TRUE se la colonna è una colonna Identity. In caso contrario, SQL_FALSE.

Per altre informazioni sui parametri con valori di tabella, vedere Parametri con valori di tabella (ODBC).

Supporto di SQLColumns per le caratteristiche avanzate di data e ora

Per informazioni sui valori restituiti per i tipi di data/ora, vedere Metadati del catalogo.

Per altre informazioni, vedere Miglioramenti di data e ora (ODBC).

Supporto di SQLColumns per tipi CLR definiti dall'utente di grandi dimensioni

SQLColumns supporta i tipi CLR definiti dall'utente di grandi dimensioni. Per altre informazioni, vedere Tipi di User-Defined CLR di grandi dimensioni (ODBC).

Supporto di SQLColumns per colonne di tipo sparse

Due SQL Server colonne specifiche sono state aggiunte al set di risultati per SQLColumns:

Nome colonna Tipo di dati Descrizione
SS_IS_SPARSE Smallint SQL_TRUE se una colonna è di tipo sparse. In caso contrario, SQL_FALSE.
SS_IS_COLUMN_SET Smallint SQL_TRUE se la colonna è column_set. In caso contrario, SQL_FALSE.

In conformità con la specifica ODBC, SS_IS_SPARSE e SS_IS_COLUMN_SET vengono visualizzate prima di tutte le colonne specifiche del driver aggiunte alle versioni SQL Server precedenti a SQL Server 2008 e dopo tutte le colonne richieste da ODBC stesso.

Il set di risultati restituito da SQLColumns dipende dall'impostazione di SQL_SOPT_SS_NAME_SCOPE. Per altre informazioni, vedere SQLSetStmtAttr.

Per altre informazioni sulle colonne sparse in ODBC, vedere Supporto colonne sparse (ODBC).

Vedere anche

Funzione SQLColumns
Dettagli di implementazione dell'API ODBC