Coleções de esquemas comuns
Aplicável a: .NET Framework .NET .NET Standard
As coleções de esquemas comuns são as coleções de esquemas que são implementadas por todos os provedores gerenciados do .NET. Consulte um provedor gerenciado do .NET para determinar a lista de coleções de esquemas compatíveis chamando o método GetSchema
sem argumentos ou com o nome da coleção de esquemas "MetaDataCollections". Esse método retornará uma DataTable com uma lista de coleções de esquemas compatíveis, o número de restrições ao qual cada uma dá suporte e o número de partes de identificador usado por elas. Essas coleções descrevem todas as colunas necessárias. Os provedores são livres para adicionar colunas se desejado. Por exemplo, o Provedor de Dados Microsoft SqlClient para SQL Server adiciona ParameterName
à coleção de restrições.
Se um provedor não puder determinar o valor de uma coluna necessária, ele retornará nulo.
Para obter mais informações sobre como usar os métodos GetSchema
, confira GetSchema e coleções de esquemas.
MetaDataCollections
Essa coleção expõe informações sobre todas as coleções de esquemas com suporte do provedor que é usado atualmente para se conectar ao banco de dados.
ColumnName | Tipo de dados | Descrição |
---|---|---|
CollectionName | string |
O nome da coleção a ser transmitida para o método GetSchema para retornar a coleção. |
NumberOfRestrictions | int |
O número de restrições que podem ser especificadas para a coleção. |
NumberOfIdentifierParts | int |
O número de partes no nome do objeto de banco de dados/identificador composto. Por exemplo, no SQL Server, o valor seria três para tabelas e quatro para colunas. |
DataSourceInformation
Essa coleção de esquemas expõe informações sobre a fonte de dados à qual o Provedor de Dados Microsoft SqlClient para SQL Server está conectado no momento.
ColumnName | Tipo de dados | Descrição |
---|---|---|
CompositeIdentifierSeparatorPattern | string |
A expressão regular usada para corresponder os separadores compostos em um identificador composto. Por exemplo, \. (para o SQL Server).Um identificador composto normalmente é o que é usado para um nome de objeto de banco de dados, por exemplo: pubs.dbo.authors ou pubs@dbo.authors .Para o SQL Server, use a expressão regular \. . |
DataSourceProductName | string |
O nome do produto acessado pelo provedor, como "SQLServer". |
DataSourceProductVersion | string |
Indica a versão do produto acessada pelo provedor, no formato nativo de fontes de dados e não no formato da Microsoft. Em alguns casos, DataSourceProductVersion e DataSourceProductVersionNormalized terão o mesmo valor. |
DataSourceProductVersionNormalized | string |
Uma versão normalizada para a fonte de dados, de modo que ela possa ser comparada com String.Compare() . Esse formato é consistente para todas as versões do provedor a fim de impedir que a versão 10 seja classificada entre a versão 1 e a versão 2.Por exemplo, o SQL Server usa o formato nn.nn.nnnn típico da Microsoft.Em alguns casos, DataSourceProductVersion e DataSourceProductVersionNormalized terão o mesmo valor. |
GroupByBehavior | GroupByBehavior | Especifica a relação entre as colunas em uma cláusula GROUP BY e as colunas não agregadas na lista de seleção. |
IdentifierPattern | string |
Uma expressão regular que corresponde a um identificador e tem um valor de correspondência do identificador. Por exemplo, [A-Za-z0-9_#$] . |
IdentifierCase | IdentifierCase | Indica se identificadores que não estão entre aspas são tratados como diferenciando maiúsculas de minúsculas. |
OrderByColumnsInSelect | bool |
Especifica se as colunas em uma cláusula ORDER BY precisam estar na lista de seleção. Um valor true indica que é necessário que eles estejam na lista de seleção. Um valor false indica que não é necessário que eles estejam na lista de seleção. |
ParameterMarkerFormat | string |
Uma cadeia de caracteres de formato que representa como formatar um parâmetro. Se os parâmetros nomeados forem compatíveis com a fonte de dados, o primeiro espaço reservado nessa cadeia de caracteres deverá ser o local em que o nome do parâmetro deve ser formatado. Por exemplo, se a fonte de dados espera que os parâmetros sejam nomeados e prefixados com um : , essa cadeia de caracteres será :{0} . Ao formatar esse parâmetro com um nome de p1 , a cadeia de caracteres resultante será :p1 .Se a fonte de dados esperar que os parâmetros sejam prefixados com o @ , mas os nomes já os incluírem, essa cadeia de caracteres será "{0} ", e o resultado da formatação de um parâmetro chamado @p1 será apenas @p1 .Para as fontes de dados que não esperam parâmetros nomeados e esperam o uso do caractere ? , a cadeia de caracteres de formato pode ser especificada como ? , o que ignora o nome do parâmetro. |
ParameterMarkerPattern | string |
Uma expressão regular que corresponde a um marcador de parâmetro. Ele terá um valor de correspondência do nome do parâmetro, se houver. Por exemplo, se houver suporte para parâmetros nomeados com um caractere @ à esquerda que será incluído no nome do parâmetro, esse padrão será (\@[A-Za-z0-9_$#]*) .No entanto, se houver suporte para parâmetros nomeados com um : como o caractere à esquerda e ele não fizer parte do nome do parâmetro, esse padrão será :([A-Za-z0-9_$#]\*) .Se a fonte de dados não der suporte a parâmetros nomeados, esse padrão será ? . |
ParameterNameMaxLength | int |
O tamanho máximo de um nome de parâmetro em caracteres. O Visual Studio espera que, se houver suporte para nomes de parâmetro, o valor mínimo para o tamanho máximo será de 30 caracteres. Se a fonte de dados não der suporte a parâmetros nomeados, essa propriedade retornará zero. |
ParameterNamePattern | string |
Uma expressão regular que corresponde aos nomes de parâmetros válidos. Fontes de dados diferentes têm regras diferentes em relação aos caracteres que podem ser usados como nomes de parâmetros. O Visual Studio espera que, se houver suporte para nomes de parâmetros, os caracteres \p{Lu}\p{Ll}\p{Lt}\p{Lm}\p{Lo}\p{Nl}\p{Nd} sejam o conjunto mínimo de caracteres compatíveis válidos para nomes de parâmetros. |
QuotedIdentifierPattern | string |
Uma expressão regular que corresponde a um identificador entre aspas e tem um valor de correspondência do próprio identificador sem aspas. Por exemplo, se a fonte de dados tiver usado aspas duplas para identificar identificadores entre aspas, esse padrão será (([^\\"]\|\\"\\")*) . |
QuotedIdentifierCase | IdentifierCase | Indica se os identificadores entre aspas são tratados como diferenciando maiúsculas de minúsculas. |
StatementSeparatorPattern | string |
Uma expressão regular que corresponde ao separador de instrução. |
StringLiteralPattern | string |
Uma expressão regular que corresponde a um literal de cadeia de caracteres e tem um valor de correspondência do próprio literal. Por exemplo, se a fonte de dados usou aspas simples para identificar cadeias de caracteres, esse padrão será ('([^']\|'')*') ' |
SupportedJoinOperators | SupportedJoinOperators | Especifica quais tipos de instruções SQL de junção são compatíveis com a fonte de dados. |
DataTypes
Essa coleção de esquemas expõe informações sobre os tipos de dados compatíveis com o banco de dados ao qual o provedor está atualmente conectado.
ColumnName | Tipo de dados | Descrição |
---|---|---|
TypeName | string |
O nome de tipo de dados específico do provedor. |
ProviderDbType | int |
O valor do tipo específico do provedor que deve ser usado ao especificar o tipo de um parâmetro. Por exemplo, SqlDbType.Money . |
ColumnSize | long |
O comprimento de uma coluna ou parâmetro não numérico. Esse valor se refere ao máximo ou ao comprimento definido para esse tipo pelo provedor. Para dados de caractere, esse valor é o máximo ou o tamanho definido em unidades, definido pela fonte de dados. Para tipos de dados de data/hora, esse valor é o tamanho da representação de cadeia de caracteres (supondo que o máximo permitiu a precisão do componente em segundos fracionários). Se o tipo de dados for numérico, esse valor será o limite superior na precisão máxima do tipo de dados. |
CreateFormat | string |
Cadeia de caracteres de formato que representa como adicionar essa coluna a uma instrução de definição de dados, como CREATE TABLE. Cada elemento da matriz CreateParameter deve ser representado por um "marcador de parâmetro" na cadeia de caracteres de formato.Por exemplo, o tipo de dados SQL DECIMAL exige uma precisão e uma escala. Nesse caso, a cadeia de caracteres de formato será DECIMAL({0},{1}) . |
CreateParameters | string |
Os parâmetros de criação que precisam ser especificados ao criar uma coluna desse tipo de dados. Cada parâmetro de criação é listado na cadeia de caracteres, separado por uma vírgula na ordem em que deve ser fornecido. Por exemplo, o tipo de dados SQL DECIMAL exige uma precisão e uma escala. Nesse caso, os parâmetros de criação devem conter a cadeia de caracteres "precisão, escala". Em um comando de texto, para criar uma coluna DECIMAL com uma precisão igual a 10 e uma escala igual a 2, o valor da coluna CreateFormat poderá ser DECIMAL({0},{1}) e a especificação de tipo completa será DECIMAL(10,2) . |
Tipo de dados | string |
O nome do tipo .NET do tipo de dados. |
IsAutoincrementable | bool |
true – Os valores desse tipo de dados podem ser incrementados automaticamente.false – Os valores desse tipo de dados podem não ser incrementados automaticamente.Essa propriedade apenas indica se uma coluna desse tipo de dados pode ser incrementada automaticamente, não que todas as colunas desse tipo sejam incrementadas automaticamente. |
IsBestMatch | bool |
true – O tipo de dados é a melhor correspondência entre todos os tipos de dados do armazenamento de dados e o tipo de dados .NET indicado pelo valor na coluna DataType .false – O tipo de dados não é a melhor correspondência.Para cada conjunto de linhas no qual o valor da coluna DataType for idêntico, a coluna IsBestMatch será definida como true em apenas uma linha. |
IsCaseSensitive | bool |
true – O tipo de dados é um tipo de caractere e diferencia maiúsculas de minúsculas.false – O tipo de dados não é um tipo de caractere ou não diferencia maiúsculas de minúsculas. |
IsFixedLength | bool |
true – Colunas desse tipo de dados criadas pela DDL (linguagem de definição de dados) terão um comprimento fixo.false – Colunas desse tipo de dados criadas pela DDL terão um comprimento variável.DBNull.Value – Não se sabe se o provedor mapeará esse campo com uma coluna de comprimento fixo ou variável. |
IsFixedPrecisionScale | bool |
true – O tipo de dados tem uma precisão e uma escala fixas.false – O tipo de dados não tem uma precisão e uma escala fixas. |
IsLong | bool |
true – O tipo de dados contém dados muito longos; a definição de dados muito longos é específica do provedor.false – O tipo de dados não contém dados muito longos. |
IsNullable | bool |
true – O tipo de dados permite valores nulos.false – O tipo de dados não permite valores nulos.DBNull.Value – Não se sabe se tipo de dados permite valores nulos. |
IsSearchable | bool |
true – O tipo de dados pode ser usado em uma cláusula WHERE com qualquer operador, exceto o predicado LIKE.false – O tipo de dados não pode ser usado em uma cláusula WHERE com nenhum operador, exceto o predicado LIKE. |
IsSearchableWithLike | bool |
true – O tipo de dados pode ser usado com o predicado LIKE.false – O tipo de dados não pode ser usado com o predicado LIKE. |
IsUnsigned | bool |
true – O tipo de dados é sem sinal.false – O tipo de dados é com sinal.DBNull.Value – Não se aplica ao tipo de dados. |
MaximumScale | short |
Se o indicador de tipo for um tipo numérico, esse valor será o número máximo de dígitos permitidos à direita do ponto decimal. Do contrário, esse valor será DBNull.Value . |
MinimumScale | short |
Se o indicador de tipo for um tipo numérico, esse valor será o número mínimo de dígitos permitidos à direita do ponto decimal. Do contrário, esse valor será DBNull.Value . |
IsConcurrencyType | bool |
true – O tipo de dados é atualizado pelo banco de dados sempre que a linha é alterada e o valor da coluna é diferente de todos os valores anteriores.false – O tipo de dados não é atualizado pelo banco de dados sempre que a linha é alterada.DBNull.Value – O banco de dados não dá suporte a esse tipo de dado. |
IsLiteralSupported | bool |
true – O tipo de dados pode ser expresso como um literal.false – O tipo de dados não pode ser expresso como um literal. |
LiteralPrefix | string |
O prefixo aplicado a um literal específico. |
LiteralSuffix | string |
O sufixo aplicado a um literal específico. |
Restrições
Essa coleção de esquemas expôs informações sobre as restrições compatíveis com o provedor que é atualmente usado para se conectar ao banco de dados.
ColumnName | Tipo de dados | Descrição |
---|---|---|
CollectionName | string |
O nome da coleção à qual essas restrições se aplicam. |
RestrictionName | string |
O nome da restrição na coleção. |
RestrictionDefault | string |
Ignorado. |
RestrictionNumber | int |
A localização real nas restrições de coleções em que essa restrição específica se enquadra. |
ReservedWords
Essa coleção de esquemas expõe informações sobre as palavras reservadas pelo banco de dados ao qual o provedor está atualmente conectado.
ColumnName | Tipo de dados | Descrição |
---|---|---|
ReservedWord | string |
Palavra reservada específica do provedor. |