OdbcCommandBuilder 类

定义

自动生成用于协调对 DataSet 的更改与关联的数据源的单表命令。 此类不能被继承。

public ref class OdbcCommandBuilder sealed : System::Data::Common::DbCommandBuilder
public ref class OdbcCommandBuilder sealed : System::ComponentModel::Component
public sealed class OdbcCommandBuilder : System.Data.Common.DbCommandBuilder
public sealed class OdbcCommandBuilder : System.ComponentModel.Component
type OdbcCommandBuilder = class
    inherit DbCommandBuilder
type OdbcCommandBuilder = class
    inherit Component
Public NotInheritable Class OdbcCommandBuilder
Inherits DbCommandBuilder
Public NotInheritable Class OdbcCommandBuilder
Inherits Component
继承
继承
OdbcCommandBuilder

示例

以下示例使用 OdbcCommand以及 OdbcDataAdapterOdbcConnection从数据源中选择行。 该示例传递了初始化DataSet的 、连接字符串、SQL SELECT 语句的查询字符串,以及作为数据源表名称的字符串。 然后,该示例创建一个 OdbcCommandBuilder

public static DataSet SelectOdbcSrvRows(string connectionString,
    string queryString, string tableName)
{
    DataSet dataSet = new DataSet();
    using (OdbcConnection connection = new OdbcConnection(connectionString))
    {
        OdbcDataAdapter adapter = new OdbcDataAdapter();
        adapter.SelectCommand =
            new OdbcCommand(queryString, connection);
        OdbcCommandBuilder builder =
            new OdbcCommandBuilder(adapter);

        connection.Open();

        adapter.Fill(dataSet, tableName);

        //code to modify data in DataSet here

        //Without the OdbcCommandBuilder this line would fail
        adapter.Update(dataSet, tableName);
    }
    return dataSet;
}
Public Function SelectOdbcSrvRows( _
    ByVal connectionString As String, ByVal queryString As String, _
    ByVal tableName As String) As DataSet

    Dim dataSet As New DataSet()

    Using connection As New OdbcConnection(connectionString)
        Dim adapter As New OdbcDataAdapter()
        adapter.SelectCommand = _
            New OdbcCommand(queryString, connection)
        Dim builder As New OdbcCommandBuilder(adapter)

        connection.Open()

        adapter.Fill(dataSet, tableName)

        ' Code to modify data in DataSet here 

        ' Without the OdbcCommandBuilder this line would fail.
        adapter.Update(dataSet, tableName)
    End Using

    Return dataSet
End Function

注解

OdbcDataAdapter不会自动生成协调对与数据源关联的 所做的更改DataSet所需的 SQL 语句。 但是,可以通过设置 SelectCommandOdbcDataAdapter属性创建一个OdbcCommandBuilder对象,该对象为单表更新生成 SQL 语句。 然后,生成 OdbcCommandBuilder 未设置的任何其他 SQL 语句。

与其对应OdbcCommandBuilder项之间的关系OdbcDataAdapter始终是一对一的。 若要创建此对应关系,请设置 OdbcDataAdapter 对象的 属性 OdbcCommandBuilder 。 这会导致 OdbcCommandBuilder 将自身注册为侦听器,从而生成影响 的事件的RowUpdatingDataSet输出。

若要生成 INSERT、UPDATE 或 DELETE 语句, OdbcCommandBuilder 使用 SelectCommand 属性检索所需的元数据集。 如果在检索元数据后(例如在第一次更新之后)更改 的值 SelectCommand ,则应调用 RefreshSchema 方法来更新元数据。

注意

如果分配给属性的 SelectCommand SELECT 语句使用别名列名,则生成的 INSERT、UPDATE 和 DELETE 语句可能不准确或失败。 如果基础 ODBC 驱动程序无法使用) 的SQL_DESC_BASE_COLUMN_NAME值 SQLColAttribute (为别名列名提供适当的基列名称,则别名可以在生成的 INSERT、UPDATE 和 DELETE 语句中使用。 例如,Microsoft ODBC Driver for Oracle 返回别名作为基列名称。 因此,生成的 INSERT、UPDATE 和 DELETE 语句将导致错误。

OdbcCommandBuilder使用 Connection引用的 SelectCommandCommandTimeoutTransaction 属性。 如果修改了其中一个或多个属性,或者更改了属性本身的值SelectCommand,则用户应调用 RefreshSchema 。 否则, InsertCommandUpdateCommandDeleteCommand 属性将保留其以前的值。

如果调用 DisposeOdbcCommandBuilder 则会取消与 OdbcDataAdapter的关联,并且不再使用生成的命令。

构造函数

OdbcCommandBuilder()

初始化 OdbcCommandBuilder 类的新实例。

OdbcCommandBuilder(OdbcDataAdapter)

使用关联的 OdbcCommandBuilder 对象初始化 OdbcDataAdapter 类的新实例。

属性

CanRaiseEvents

获取一个指示组件是否可以引发事件的值。

(继承自 Component)
CatalogLocation

获取或设置 DbCommandBuilder 类的实例的 CatalogLocation

(继承自 DbCommandBuilder)
CatalogSeparator

获取或设置一个字符串,该字符串用作 DbCommandBuilder 类的实例的目录分隔符。

(继承自 DbCommandBuilder)
ConflictOption

指定哪个 ConflictOption 将由 DbCommandBuilder 使用。

(继承自 DbCommandBuilder)
Container

获取包含 IContainerComponent

(继承自 Component)
DataAdapter

获取或设置此 OdbcDataAdapter 对象将为其生成 SQL 语句的 OdbcCommandBuilder 对象。

DesignMode

获取一个值,用以指示 Component 当前是否处于设计模式。

(继承自 Component)
Events

获取附加到此 Component 的事件处理程序的列表。

(继承自 Component)
QuotePrefix

获取或设置使用其名称包含空格或保留标记等字符的数据库对象(例如,表或列)时使用的开始字符。

QuotePrefix

获取或设置指定其名称包含空格或保留标记等字符的数据库对象(例如,表或列)时使用的开始字符。

(继承自 DbCommandBuilder)
QuoteSuffix

获取或设置使用其名称包含空格或保留标记等字符的数据库对象(例如,表或列)时使用的结束字符。

QuoteSuffix

获取或设置一个或多个结束字符,供指定其名称中包含空格或保留标记等字符的数据库对象(例如,表或列)时使用。

(继承自 DbCommandBuilder)
SchemaSeparator

获取或设置要用作架构标识符和任何其他标识符之间的分隔符的字符。

(继承自 DbCommandBuilder)
SetAllValues

指定 update 语句中是包含所有列值还是仅包含更改的列值。

(继承自 DbCommandBuilder)
Site

获取或设置 ComponentISite

(继承自 Component)

方法

ApplyParameterInfo(DbParameter, DataRow, StatementType, Boolean)

允许 DbCommandBuilder 类的提供程序实现处理附加参数属性。

(继承自 DbCommandBuilder)
CreateObjRef(Type)

创建一个对象,该对象包含生成用于与远程对象进行通信的代理所需的全部相关信息。

(继承自 MarshalByRefObject)
DeriveParameters(OdbcCommand)

从在 OdbcCommand 中指定的存储过程中检索参数信息并填充指定的 Parameters 对象的 OdbcCommand 集合。

Dispose()

释放由 Component 使用的所有资源。

(继承自 Component)
Dispose(Boolean)

释放由 DbCommandBuilder 占用的非托管资源,还可以另外再释放托管资源。

(继承自 DbCommandBuilder)
Dispose(Boolean)

释放由 Component 占用的非托管资源,还可以另外再释放托管资源。

(继承自 Component)
Equals(Object)

确定指定对象是否等于当前对象。

(继承自 Object)
GetDeleteCommand()

获取在数据源中执行删除操作所需的自动生成的 OdbcCommand 对象。

GetDeleteCommand(Boolean)

获取在数据源中执行删除操作所需的自动生成的 OdbcCommand 对象。

GetHashCode()

作为默认哈希函数。

(继承自 Object)
GetInsertCommand()

获取在数据源中执行插入操作所需的自动生成的 OdbcCommand 对象。

GetInsertCommand(Boolean)

获取在数据源中执行插入操作所需的自动生成的 OdbcCommand 对象。

GetLifetimeService()
已过时.

检索控制此实例的生存期策略的当前生存期服务对象。

(继承自 MarshalByRefObject)
GetParameterName(Int32)

以 格式 @p#返回指定参数的名称。 在生成自定义命令生成器时使用。

(继承自 DbCommandBuilder)
GetParameterName(String)

给定部分参数名,返回完整参数名。

(继承自 DbCommandBuilder)
GetParameterPlaceholder(Int32)

返回该参数在关联的 SQL 语句中的占位符。

(继承自 DbCommandBuilder)
GetSchemaTable(DbCommand)

返回 DbCommandBuilder 的架构表。

(继承自 DbCommandBuilder)
GetService(Type)

返回一个对象,该对象表示由 Component 或它的 Container 提供的服务。

(继承自 Component)
GetType()

获取当前实例的 Type

(继承自 Object)
GetUpdateCommand()

获取在数据源中执行更新操作所需的自动生成的 OdbcCommand 对象。

GetUpdateCommand(Boolean)

获取在数据源中执行更新操作所需的自动生成的 OdbcCommand 对象。

InitializeCommand(DbCommand)

重置 CommandTimeout 上的 TransactionCommandTypeUpdateRowSourceDbCommand 属性。

(继承自 DbCommandBuilder)
InitializeLifetimeService()
已过时.

获取生存期服务对象来控制此实例的生存期策略。

(继承自 MarshalByRefObject)
MemberwiseClone()

创建当前 Object 的浅表副本。

(继承自 Object)
MemberwiseClone(Boolean)

创建当前 MarshalByRefObject 对象的浅表副本。

(继承自 MarshalByRefObject)
QuoteIdentifier(String, OdbcConnection)

给定了具有正确的目录大小写设置且不带引号的标识符时,返回该标识符的正确的带引号形式。 这包括正确地转义该标识符中的任何嵌入引号。

QuoteIdentifier(String)

给定了具有正确的目录大小写设置且不带引号的标识符时,返回该标识符的正确的带引号形式。 这包括正确地转义该标识符中的任何嵌入引号。

RefreshSchema()

清除与此 OdbcCommandBuilder 关联的命令。

RefreshSchema()

清除与此 DbCommandBuilder 关联的命令。

(继承自 DbCommandBuilder)
RowUpdatingHandler(RowUpdatingEventArgs)

添加 RowUpdating 事件的事件处理程序。

(继承自 DbCommandBuilder)
SetRowUpdatingHandler(DbDataAdapter)

注册 DbCommandBuilder 以处理 RowUpdatingDbDataAdapter 事件。

(继承自 DbCommandBuilder)
ToString()

返回包含 Component 的名称的 String(如果有)。 不应重写此方法。

(继承自 Component)
UnquoteIdentifier(String, OdbcConnection)

给定了带引号的标识符时,返回该标识符的正确的不带引号形式,包括正确地非转义该标识符中的任何嵌入引号。

UnquoteIdentifier(String)

给定了带引号的标识符时,返回该标识符的正确的不带引号形式,包括正确地非转义该标识符中的任何嵌入引号。

事件

Disposed

在通过调用 Dispose() 方法释放组件时发生。

(继承自 Component)

适用于

另请参阅