添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

This browser is no longer supported.

Upgrade to Microsoft Edge to take advantage of the latest features, security updates, and technical support.

Download Microsoft Edge More info about Internet Explorer and Microsoft Edge

Gets or sets a value that indicates whether the database column is an identity column.

Namespace: Microsoft.Web.Management.DatabaseManager
Assembly: Microsoft.Web.Management.DatabaseManager (in Microsoft.Web.Management.DatabaseManager.dll)

Syntax

'Declaration
Public Property IsIdentity As Boolean
'Usage
Dim instance As Column
Dim value As Boolean
value = instance.IsIdentity
instance.IsIdentity = value
public bool IsIdentity { get; set; }
public:
property bool IsIdentity {
    bool get ();
    void set (bool value);
function get IsIdentity () : boolean
function set IsIdentity (value : boolean)

Property Value

Type: System.Boolean
true if the column an identity column; otherwise, false.

Examples

The following code sample shows how to use the GetTableInfo method to retrieve the table information for the table name from a database.

This example also provides helper methods that perform additional database tasks.

' Retrieve the information about a table. Public Function GetTableInfo( _ ByVal connectionString As String, _ ByVal tableName As String, _ ByVal schema As String) As TableInfo _ Implements Microsoft.Web.Management.DatabaseManager.IDbTableManager.GetTableInfo ' Create a new TableInfo object. Dim info As TableInfo = New TableInfo ' Create a connection to the database. Dim connection As OleDbConnection = New OleDbConnection(connectionString) connection.Open() ' Retrieve the table name. info.Name = tableName ' Retrieve the list of table columns. GetColumns(connection, tableName, schema, info.Columns) ' Retrieve the list of the table's foreign keys. GetForeignKeys(connection, tableName, info.ForeignKeys) ' Retrieve the list of the table's indices. GetIndexes(connection, tableName, info.Indexes) ' Return the table information. Return info End Function ' Retrieve the list of table colums. Private Sub GetColumns( _ ByVal connection As OleDbConnection, _ ByVal tableName As String, _ ByVal tableSchema As String, _ ByVal columns As ICollection(Of Column)) Dim restrictions() As String = New String() {Nothing, Nothing, tableName, Nothing} Dim columnSchema As DataTable ' Retrieve a list of primary keys for a table. Dim primaryKeys() As String = GetPrimaryKey(connection.ConnectionString, tableName, tableSchema) ' Open the schema information for the columns. columnSchema = connection.GetSchema(OleDbMetaDataCollectionNames.Columns, restrictions) ' Enumerate the table's columns. For Each row As DataRow In columnSchema.Rows ' Create a new column object. Dim column As Column = New Column ' Retrieve the column name. column.Name = row("COLUMN_NAME").ToString column.OriginalName = row("COLUMN_NAME").ToString ' Test if the column allows nulls. column.AllowNulls = CType(row("IS_NULLABLE"), Boolean) ' Retrieve the column type. column.TypeInfo = GetColumnType(connection, OleDbTypeToString(CType(Int32.Parse(row("DATA_TYPE").ToString), OleDbType))) ' Retrieve the column's default value. If DBNull.Value.Equals(row("COLUMN_DEFAULT")) Then column.DefaultValue = "Null" column.DefaultValue = row("COLUMN_DEFAULT").ToString() End If ' Retrieve the column's precision. If DBNull.Value.Equals(row("NUMERIC_PRECISION")) Then column.Precision = 0 column.Precision = Int32.Parse(CType(row("NUMERIC_PRECISION"), String)) End If ' Retrieve the column's scale. If DBNull.Value.Equals(row("NUMERIC_SCALE")) Then column.Scale = 0 column.Scale = Int32.Parse(CType(row("NUMERIC_SCALE"), String)) End If ' Specify if the column is a primary key. column.InPrimaryKey = primaryKeys.Contains(row("COLUMN_NAME").ToString) ' Specify that the column is not an identity column. column.IsIdentity = False ' Retrieve the column length. If CType(Int32.Parse(row("DATA_TYPE").ToString()), OleDbType) <> OleDbType.WChar Then column.Length = -1 column.Length = Int32.Parse(row("CHARACTER_MAXIMUM_LENGTH").ToString()) End If ' Append the column to the list. columns.Add(column) End Sub ' Determine the type of a column. Private Function GetColumnType( _ ByVal connection As OleDbConnection, _ ByVal columnName As String) As TypeInfo ' Retrieve the list of column types. Dim serverTypes As ICollection = GetServerTypes(connection.ConnectionString) ' Enumerate the columns. For Each type As TypeInfo In serverTypes ' Return the column type if it is found. If type.Name.Equals(columnName) Then Return type End If ' Raise an exception if the column type was not found. Throw New ArgumentException(("Unknown column type: " + columnName)) End Function ' Retrieve the list of a table's indices. Private Sub GetIndexes( _ ByVal connection As OleDbConnection, _ ByVal tableName As String, _ ByVal indices As IList(Of Index)) Dim restrictions() As String = New String() {Nothing, Nothing, Nothing, Nothing, tableName} Dim schema As DataTable ' Open the schema information for the indices. schema = connection.GetOleDbSchemaTable(OleDbSchemaGuid.Indexes, restrictions) ' Enumerate the table's indices. For Each row As DataRow In schema.Rows ' Create a new index. Dim dbIndex As Index = New Index ' Append the index name. dbIndex.Name = row("INDEX_NAME").ToString dbIndex.OriginalName = row("INDEX_NAME").ToString ' Append the index's uniqueness. dbIndex.Unique = CType(row("UNIQUE"), Boolean) ' Specify the index type. If (CType(row("PRIMARY_KEY"), Boolean) = True) Then dbIndex.IndexType = IndexType.PrimaryKey dbIndex.IndexType = IndexType.Index End If ' Create an index column object. Dim column As IndexColumn = New IndexColumn column.Name = row("COLUMN_NAME").ToString ' Specify whether the index is descending. If (Int32.Parse(row("COLLATION").ToString) = 2) Then column.Descending = True column.Descending = False End If dbIndex.Columns.Add(column) ' Append the index to the list. indices.Add(dbIndex) End Sub ' Retrieve the list of a table's foreign keys. Private Sub GetForeignKeys( _ ByVal connection As OleDbConnection, _ ByVal tableName As String, _ ByVal foreignKeys As IList(Of ForeignKey)) Dim restrictions() As String = New String() {Nothing} Dim schema As DataTable ' Open the schema information for the foreign keys. schema = connection.GetOleDbSchemaTable(OleDbSchemaGuid.Foreign_Keys, restrictions) ' Enumerate the table's foreign keys. For Each row As DataRow In schema.Rows Dim dbForeignKey As ForeignKey = New ForeignKey dbForeignKey.Name = row("FK_NAME").ToString dbForeignKey.OriginalName = row("FK_NAME").ToString dbForeignKey.FKTableName = row("FK_TABLE_NAME").ToString Dim fkc As ForeignKeyColumn = New ForeignKeyColumn fkc.Name = row("FK_COLUMN_NAME").ToString dbForeignKey.FKColumns.Add(fkc) dbForeignKey.FKTableSchema = schema.ToString dbForeignKey.PKTableName = row("PK_TABLE_NAME").ToString Dim pkc As ForeignKeyColumn = New ForeignKeyColumn pkc.Name = row("PK_COLUMN_NAME").ToString dbForeignKey.PKColumns.Add(pkc) dbForeignKey.PKTableSchema = schema.ToString foreignKeys.Add(dbForeignKey) End Sub ' Map OLEDB data types to their respective string descriptions. Friend Shared Function OleDbTypeToString(ByVal type As OleDbType) As String Select Case (type) Case OleDbType.Binary Return "Binary" Case OleDbType.Boolean Return "Bit" Case OleDbType.UnsignedTinyInt Return "Byte" Case OleDbType.TinyInt Return "TinyInt" Case OleDbType.Integer Return "Integer" Case OleDbType.Currency Return "Currency" Case OleDbType.Date Return "DateTime" Case OleDbType.Double Return "Float" Case OleDbType.Guid Return "UniqueIdentifier" Case OleDbType.Char, OleDbType.WChar Return "Text" Case OleDbType.Single Return "Real" Case OleDbType.SmallInt Return "SmallInt" Case OleDbType.Numeric, OleDbType.Decimal Return "Decimal" Case Else Return "Unknown" End Select End Function // Retrieve the information about a table. public TableInfo GetTableInfo(string connectionString, string tableName, string schema) // Create a new TableInfo object. TableInfo info = new TableInfo(); // Create a connection to the database. using (OleDbConnection connection = new OleDbConnection(connectionString)) connection.Open(); // Retrieve the table name. info.Name = tableName; // Retrieve the list of table columns. GetColumns(connection, tableName, schema, info.Columns); // Retrieve the list of the table's foreign keys. GetForeignKeys(connection, tableName, info.ForeignKeys); // Retrieve the list of the table's indices. GetIndexes(connection, tableName, info.Indexes); // Return the table information. return info; // Retrieve the list of table colums. private void GetColumns(OleDbConnection connection, string tableName, string tableSchema, ICollection<Column> columns) String[] restrictions = new string[] { null, null, tableName, null }; DataTable columnSchema; // Retrieve a list of primary keys for a table. string[] primaryKeys = GetPrimaryKey( connection.ConnectionString, tableName, tableSchema); // Open the schema information for the columns. columnSchema = connection.GetSchema( OleDbMetaDataCollectionNames.Columns, restrictions); // Enumerate the table's columns. foreach (DataRow row in columnSchema.Rows) // Create a new column object. Column column = new Column(); // Retrieve the column name. column.Name = row["COLUMN_NAME"].ToString(); column.OriginalName = row["COLUMN_NAME"].ToString(); // Test if the column allows nulls. column.AllowNulls = (bool)row["IS_NULLABLE"]; // Retrieve the column type. column.TypeInfo = GetColumnType(connection, OleDbTypeToString((OleDbType) Int32.Parse(row["DATA_TYPE"].ToString()))); // Retrieve the column's default value. column.DefaultValue = ((row["COLUMN_DEFAULT"] as DBNull) != null) ? "Null" : row["COLUMN_DEFAULT"].ToString(); // Retrieve the column's precision. column.Precision = ((row["NUMERIC_PRECISION"] as DBNull) != null) ? 0 : Int32.Parse(row["NUMERIC_PRECISION"].ToString()); // Retrieve the column's scale. column.Scale = ((row["NUMERIC_SCALE"] as DBNull) != null) ? 0 : Int32.Parse(row["NUMERIC_SCALE"].ToString()); // Specify if the column is a primary key. column.InPrimaryKey = primaryKeys.Contains(row["COLUMN_NAME"].ToString()); // Specify that the column is not an identity column. column.IsIdentity = false; // Retrieve the column length. column.Length = ((OleDbType)Int32.Parse(row["DATA_TYPE"].ToString()) != OleDbType.WChar) ? -1 : Int32.Parse(row["CHARACTER_MAXIMUM_LENGTH"].ToString()); // Append the column to the list. columns.Add(column); // Determine the type of a column. private TypeInfo GetColumnType(OleDbConnection connection, string columnName) // Retrieve the list of column types. ICollection<TypeInfo> serverTypes = GetServerTypes(connection.ConnectionString); // Enumerate the columns. foreach (TypeInfo type in serverTypes) // Return the column type if it is found. if (type.Name.Equals(columnName)) return type; // Raise an exception if the column type was not found. throw new ArgumentException("Unknown column type: " + columnName); // Retrieve the list of a table's indices. private void GetIndexes(OleDbConnection connection, string tableName, IList<Index> indices) String[] restrictions = new string[] { null, null, null, null, tableName }; DataTable schema; // Open the schema information for the indices. schema = connection.GetOleDbSchemaTable(OleDbSchemaGuid.Indexes, restrictions); // Enumerate the table's indices. foreach (DataRow row in schema.Rows) // Create a new index. Index dbIndex = new Index(); // Append the index name. dbIndex.Name = row["INDEX_NAME"].ToString(); dbIndex.OriginalName = row["INDEX_NAME"].ToString(); // Append the index's uniqueness. dbIndex.Unique = (bool)row["UNIQUE"]; // Specify the index type. dbIndex.IndexType = (bool)row["PRIMARY_KEY"] == true ? IndexType.PrimaryKey : IndexType.Index; // Create an index column object. IndexColumn column = new IndexColumn(); column.Name = row["COLUMN_NAME"].ToString(); // Specify whether the index is descending. column.Descending = (Int32.Parse(row["COLLATION"].ToString()) == 2) ? true : false; dbIndex.Columns.Add(column); // Append the index to the list. indices.Add(dbIndex); // Retrieve the list of a table's foreign keys. private void GetForeignKeys(OleDbConnection connection, string tableName, IList<ForeignKey> foreignKeys) String[] restrictions = new string[] { null }; DataTable schema; // Open the schema information for the foreign keys. schema = connection.GetOleDbSchemaTable(OleDbSchemaGuid.Foreign_Keys, restrictions); // Enumerate the table's foreign keys. foreach (DataRow row in schema.Rows) ForeignKey dbForeignKey = new ForeignKey(); dbForeignKey.Name = row["FK_NAME"].ToString(); dbForeignKey.OriginalName = row["FK_NAME"].ToString(); dbForeignKey.FKTableName = row["FK_TABLE_NAME"].ToString(); ForeignKeyColumn fkc = new ForeignKeyColumn(); fkc.Name = row["FK_COLUMN_NAME"].ToString(); dbForeignKey.FKColumns.Add(fkc); dbForeignKey.FKTableSchema = schema.ToString(); dbForeignKey.PKTableName = row["PK_TABLE_NAME"].ToString(); ForeignKeyColumn pkc = new ForeignKeyColumn(); pkc.Name = row["PK_COLUMN_NAME"].ToString(); dbForeignKey.PKColumns.Add(pkc); dbForeignKey.PKTableSchema = schema.ToString(); foreignKeys.Add(dbForeignKey); // Map OLEDB data types to their respective string descriptions. internal static string OleDbTypeToString(OleDbType type) switch (type) case OleDbType.Binary: return "Binary"; case OleDbType.Boolean: return "Bit"; case OleDbType.UnsignedTinyInt: return "Byte"; case OleDbType.TinyInt: return "TinyInt"; case OleDbType.Integer: return "Integer"; case OleDbType.Currency: return "Currency"; case OleDbType.Date: return "DateTime"; case OleDbType.Double: return "Float"; case OleDbType.Guid: return "UniqueIdentifier"; case OleDbType.Char: case OleDbType.WChar: return "Text"; case OleDbType.Single: return "Real"; case OleDbType.SmallInt: return "SmallInt"; case OleDbType.Numeric: case OleDbType.Decimal: return "Decimal"; default: return "Unknown";

Permissions

  • Full trust for the immediate caller. This member cannot be used by partially trusted code. For more information, see Using Libraries from Partially Trusted Code.
  • See Also

    Reference

    Column Class

    Microsoft.Web.Management.DatabaseManager Namespace