BUG: DataRepeater コントロール更新レコードではないのは

重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。

英語版 KB:197428
この資料は、アーカイブされました。これは "現状のまま" で提供され、更新されることはありません。
現象
使用すると、DataRepeater コントロールのスクロール バーを移動するのには、データ連結ユーザー コントロールをユーザー コントロール内のフィールドへの変更データベースには保存されません。
原因
DataRepeater にデータ ソースを取得すると、データ ソースに渡されますそのBindingCollection。現在の位置は、BindingCollection を取得します。行します。また、DataRepeater の現在の行位置を取得します。通常、2 つの行と同じにする必要があります。ここではないです。両方の呼び出し同じレコード セット オブジェクトを返しますが、自分の現在の行が含まれています情報です。現在の行、DataRepeater には、ユーザーが選択すると、コレクションの行の位置を連結移動しません、したがって、データユーザー コントロール内のバインドを更新を取得しません。
解決方法
この問題を回避するには、次のいずれかを使用します。
  • 表示 ActiveX データ オブジェクト (ADO) データ コントロール (ADODC) を使用して、スクロールする連結ユーザー コントロールを使用します。
  • 隠し ADO データ コントロール (ADODC) で、フォームを使用します。レコードの変更を保存するのには、コマンド ボタンを追加します。コマンド ボタンの Click イベントに次のコードを貼り付けます。
    Private Sub SaveRecord_Click  Adodc1.Recordset.Move 0End Sub						
    次のコードは動作します。
    Private Sub SaveRecord_Click  If (Adodc1.Recordset.BOF) Then     Adodc1.Recordset.MoveNext     Adodc1.Recordset.MovePrevious  Else     Adodc1.Recordset.MovePrevious     Adodc1.Recordset.MoveNext  End IfEnd Sub						
現在、ADODC レコード セット内の別のレコードに移動になります行の位置は、BindingCollection DataRepeater と同じです。これが正常に更新するのには、そのユーザー コントロールが発生します。
状況
マイクロソフトは、これをこの資料の冒頭に記載したマイクロソフト製品のバグであること確認しています。
詳細

現象の再現手順

ユーザー コントロールを作成します。

  1. 新しい ActiveX コントロール プロジェクトを作成します。既定では、UserControl1 が作成されます。
  2. ラベルとテキスト ボックスにユーザー コントロールを追加します。「製品名」と"txtProdName"にあるテキスト ボックスの名前をラベルのキャプションを変更します。
  3. 一般の宣言での次のステートメントを配置する、ユーザー コントロール。
    Option ExplicitPublic Property Get ProdName() As String   ProdName = txtProdName.TextEnd PropertyPublic Property Let ProdName(ByVal newitem As String)   txtProdName.Text = newitem End PropertyPrivate Sub txtProdName_Change()   PropertyChanged "ProdName"End Sub						
  4. から、 ツール メニューをクリックして プロシージャの属性.クリックして、 高度な ProdName で表示されていることを確認するタブをクリックし、 名前 ボックス。
  5. 次に、以下を選択します。

    • プロパティはデータ バインドです。
    • このプロパティは、データ フィールドにバインドします。
    • デザイン時のデータ連結のコレクションを表示します。
  6. クリックしてください。 [OK].
  7. プロジェクトを名前します。 TestCtl..Ocx ファイルを作成するのには、プロジェクトをコンパイルします。

Visual Basic テスト クライアント プロジェクトを作成します。

  1. Visual Basic 6.0 の EXE プロジェクトを新規作成します。Project1 という名前のプロジェクト、Form1 という名前のフォームは、既定で作成されます。
  2. Form1 には、ADO データ コントロールや、DataRepeater コントロールに追加します。
  3. Ole Db の接続文字列を設定して、ソース プロパティのノースウィンド データベース] をポイントして ADODC を指定します。
  4. DataRepeater のデータソース、ADODC を設定します。
  5. DataRepeater コントロールの RepeatedControlName プロパティを TestCtl.UserControl1 にポイントを設定します。ユーザー コントロールは内で繰り返し表示されます、DataRepeater コントロールです。
  6. DataRepeater コントロールを右クリックします。クリックしてください。 データ リピータプロパティ.プロパティ ダイアログ ボックスで、[RepeaterBindings] タブ [PropertyName] ボックスに、ProdName プロパティを選択] をクリックします。選択、[商品名] フィールド、データ フィールド ボックスでします。クリックしてください。 追加[OK].
  7. プロジェクトを実行し、重複するデータが表示されます。
  8. データ連結ユーザー コントロールのいずれかの製品名を変更します。
  9. 下/上 ADODC を使用して、データ連結ユーザー コントロールをスクロールします。
  10. アプリケーションを終了します。
  11. 7-10 がこの時、DataRepeater のスクロール バーを使用して、データ連結ユーザー コントロールを使用する手順を繰り返します。
だけ、ADODC を使用する上下にスクロールしたときに変更を保存するされることがわかります。

データ リピータ

プロパティ

文書番号:197428 - 最終更新日: 02/22/2014 15:16:29 - リビジョン: 3.0

  • kbnosurvey kbarchive kbbug kbdatabinding kbdatabase kbctrl kbpending kbmt KB197428 KbMtja
フィードバック