2009-08-07 8 views
1

このコードでは、Oracleデータベース内のテーブル名を検索できます。行を選択すると、選択した表のすべての列が2番目のグリッド表示に表示されます。マスター詳細グリッドビュー内の複数のDataKeyNames

DatakeyName - 「Table_Name」を1つだけ使用すると、以下のコードが機能しますが、存在する場合は異なる所有者と同じテーブル名が表示されます。私は、Table_NameとOwnerの2つのフィールドに基づいて詳細を引き出したいと思います。

2つのdatakeyNamesで動作するように詳細部分を取得する方法がわかりません。

<asp:Label ID="lblTitleSrchOracleTab" runat="server" Text="Search For A Table In Oracle"></asp:Label> 
     <br /><br /> 
     <asp:Label ID="lblOracleTableName" runat="server" Text="Oracle Table Name"></asp:Label> 
     <asp:TextBox ID="txtOracleTableName" runat="server"></asp:TextBox> 
     <asp:Button ID="btnOracleTableName" runat="server" Text="Search" 
      /> 
     <br /><br /> 
    <asp:GridView ID="gvOracleTableName" runat="server" CssClass="mGrid" 
      AutoGenerateSelectButton="True" AutoGenerateColumns="False" 
       DataSourceID="sdsOracleTableName" DataKeyNames="Owner,Table_Name" > 
      <Columns> 
       <asp:BoundField DataField="OWNER" HeaderText="OWNER" SortExpression="OWNER" /> 
       <asp:BoundField DataField="TABLE_NAME" HeaderText="TABLE_NAME" 
        SortExpression="TABLE_NAME" /> 
       <asp:BoundField DataField="NUM_ROWS" HeaderText="NUM_ROWS" 
        SortExpression="NUM_ROWS" /> 
       <asp:BoundField DataField="TABLESPACE_NAME" HeaderText="TABLESPACE_NAME" 
        SortExpression="TABLESPACE_NAME" /> 
      </Columns> 
     </asp:GridView> 
     <asp:SqlDataSource ID="sdsOracleTableName" runat="server" 
      ConnectionString="<%$ ConnectionStrings:ConnectionString %>" 
      ProviderName="<%$ ConnectionStrings:ConnectionString.ProviderName %>" SelectCommand="SELECT Owner, Table_name, Num_Rows, Tablespace_name 
    FROM all_tables 
    WHERE trim(upper(table_name)) LIKE trim(upper('%' || :TableName || '%'))"> 
      <SelectParameters> 
       <asp:ControlParameter ControlID="txtOracleTableName" Name="TableName" 
        PropertyName="Text" /> 
      </SelectParameters> 
     </asp:SqlDataSource> 
     <br /><br /> 
     <asp:GridView ID="gvSelectedTableColumns" runat="server" CssClass="mGrid" 
      AutoGenerateColumns="False" DataSourceID="sdsgvSelectedTableColumns"> 
      <Columns> 
       <asp:BoundField DataField="OWNER" HeaderText="OWNER" SortExpression="OWNER" /> 
       <asp:BoundField DataField="TABLE_NAME" HeaderText="TABLE_NAME" 
        SortExpression="TABLE_NAME" /> 
       <asp:BoundField DataField="COLUMN_NAME" HeaderText="COLUMN_NAME" 
        SortExpression="COLUMN_NAME" /> 
       <asp:BoundField DataField="DATA_TYPE" HeaderText="DATA_TYPE" 
        SortExpression="DATA_TYPE" /> 
       <asp:BoundField DataField="DATA_LENGTH" HeaderText="DATA_LENGTH" 
        SortExpression="DATA_LENGTH" /> 
       <asp:BoundField DataField="NULLABLE" HeaderText="NULLABLE" 
        SortExpression="NULLABLE" /> 
      </Columns> 
      <SelectedRowStyle BorderColor="Red" Font-Bold="True" /> 
     </asp:GridView> 
     <asp:SqlDataSource ID="sdsgvSelectedTableColumns" runat="server" 
      ConnectionString="<%$ ConnectionStrings:ConnectionString %>" 


      ProviderName="<%$ ConnectionStrings:ConnectionString.ProviderName %>" SelectCommand="SELECT Owner, table_name, column_name, Data_Type, Data_Length, Nullable 
    FROM all_tab_columns 
    WHERE trim(upper(Owner)) =trim(upper(:SelectedOwner)) AND 
    trim(upper(table_name)) =trim(upper(:SelectedTableName)) 
    "> 
      <SelectParameters> 
       <asp:ControlParameter ControlID="gvOracleTableName" Name="SelectedOwner" 
        PropertyName="SelectedValue" /> 
       <asp:ControlParameter ControlID="gvOracleTableName" DefaultValue="" 
        Name="SelectedTableName" PropertyName="SelectedValue" /> 
      </SelectParameters> 
     </asp:SqlDataSource> 

答えて

0

私はついにこれを考え出しました。 Mighty Mouseはできません - 実際のコードが必要です!特に、gridview_SelectedIndexChangedイベントです。

ここで私はそれをしました。

protected void gvOracleTableName_SelectedIndexChanged(object sender, EventArgs e) 
     { 
      string SelectedOwner; 

      SelectedOwner = gvOracleTableName.SelectedRow.Cells[1].Text ; 

      string SelectedTableName; 
      SelectedTableName = gvOracleTableName.SelectedRow.Cells[2].Text; 

      lblTest.Text = SelectedOwner + " " + SelectedTableName; 





      string strConn, strSQL; 
      strConn = @""; 
      strSQL = @"SELECT Owner, table_name, column_name, Data_Type, Data_Length, Nullable FROM all_tab_columns WHERE trim(upper(Owner)) =trim(upper(:SelectedOwner)) AND trim(upper(table_name)) =trim(upper(:SelectedTableName))"; 
      using (OracleConnection cn = new OracleConnection(strConn)) 
      { 
       OracleCommand cmd = new OracleCommand(strSQL, cn); 

       cmd.Parameters.AddWithValue(":SelectedOwner", SelectedOwner); 
       cmd.Parameters.AddWithValue(":SelectedTableName", SelectedTableName); 

       cn.Open(); 

       OracleDataReader rdr = cmd.ExecuteReader(); 

       gvSelectedTableColumns.DataSource = rdr; 
       gvSelectedTableColumns.DataBind(); 

       cn.Close(); 
      } 

     } 
0

where句を拡張できませんか?

ので

from all_tables where ... and owner = 'MYOWNER' 

または

select from user_tables instead of all_tables. 
0

これは

WHERE trim(upper(Owner)) =trim(upper(:SelectedOwner)) AND 
trim(upper(table_name)) =trim(upper(:SelectedTableName)) 

あるものだというのが私の問題は、SqlDataSourceコントロールウィザードを使用するときにGridViewコントロールに偶然にを接続することで、バインドするグリッドビューのデータキーを選択することはできません。

関連する問題