2016-05-08 10 views
1

各データエントリに対して一意のMatch_IDを持つテーブルが設定されています。しかし、Teamテーブルからチーム名を収集するカスタム選択クエリを呼び出す場合、同じ2つのMatch_IDがリストされた重複行が表示されます。私は列をHome teamAway teamHome team score、およびGame dateの列で一意に表示する必要があります。チームのIDを列に表示するのではなく、チームの名前を表示したいと思います。しかし、私はまた、このGridViewを更新できることを確認したいと思います。なぜなら、ASを使用することで過去にそうすることができなくなったからです。カスタムSQL選択クエリから重複する行を削除します

これまでに、クエリが返す内容を示す画像を使用しています。私はSQLデータソースを使用しています。要するに

SELECT  MatchStatistics.Match_ID, MatchStatistics.Home_team_ID, MatchStatistics.Away_team_ID, MatchStatistics.Home_team_score, MatchStatistics.Away_team_score, MatchStatistics.Game_date, 
         Team.Team_name 
FROM   MatchStatistics INNER JOIN 
         Team ON MatchStatistics.Home_team_ID = Team.Team_ID OR MatchStatistics.Away_team_ID = Team.Team_ID 
WHERE  EXISTS 
          (SELECT DISTINCT Match_ID 
           FROM   MatchStatistics AS MatchStatistics_1) 
<asp:GridView ID="EnterMatchGridView" runat="server" AutoGenerateColumns="False" DataKeyNames="Match_ID" DataSourceID="SqlDataSource4" OnRowUpdating="EnterMatchGridView_RowUpdating" OnRowDeleting="EnterMatchGridView_RowDeleting"> 
     <Columns> 
      <asp:BoundField DataField="Match_ID" HeaderText="Match_ID" SortExpression="Match_ID" InsertVisible="False" ReadOnly="True" /> 
      <asp:TemplateField HeaderText="Home Team" SortExpression="Home_Team_Name"> 
       <EditItemTemplate> 
        <asp:TextBox ID="TextBox3" runat="server" Text='<%# Bind("Home_Team_Name") %>'></asp:TextBox> 

       </EditItemTemplate> 
       <ItemTemplate> 
        <asp:Label ID="Label2" runat="server" Text='<%# Bind("Home_Team_Name") %>'></asp:Label> 
       </ItemTemplate> 
      </asp:TemplateField> 
      <asp:TemplateField HeaderText="Away Team" SortExpression="Away_Team_Name"> 
       <EditItemTemplate> 
        <asp:TextBox ID="TextBox1" runat="server" Text='<%# Bind("Away_Team_Name") %>'></asp:TextBox> 
       </EditItemTemplate> 
       <ItemTemplate> 
        <asp:Label ID="Label1" runat="server" Text='<%# Bind("Away_Team_Name") %>'></asp:Label> 
       </ItemTemplate> 
      </asp:TemplateField> 
      <asp:TemplateField HeaderText="Home Team Score" SortExpression="Home_team_score"> 
       <EditItemTemplate> 
        <asp:TextBox ID="TextBox4" runat="server" Text='<%# Bind("Home_team_score") %>'></asp:TextBox> 
       </EditItemTemplate> 
       <ItemTemplate> 
        <asp:Label ID="Label4" runat="server" Text='<%# Bind("Home_team_score") %>'></asp:Label> 
       </ItemTemplate> 
      </asp:TemplateField> 
      <asp:TemplateField HeaderText="Away Team Score" SortExpression="Away_team_score"> 
       <EditItemTemplate> 
        <asp:TextBox ID="TextBox5" runat="server" Text='<%# Bind("Away_team_score") %>'></asp:TextBox> 
       </EditItemTemplate> 
       <ItemTemplate> 
        <asp:Label ID="Label5" runat="server" Text='<%# Bind("Away_team_score") %>'></asp:Label> 
       </ItemTemplate> 
      </asp:TemplateField> 
      <asp:TemplateField HeaderText="Date" SortExpression="Game_date"> 
       <EditItemTemplate> 
        <asp:TextBox ID="TextBox2" runat="server" Text='<%# Bind("Game_date", "{0:dd-MM-yyyy}") %>'></asp:TextBox> 
       </EditItemTemplate> 
       <ItemTemplate> 
        <asp:Label ID="Label3" runat="server" Text='<%# Bind("Game_date", "{0:dd-MM-yyyy}") %>'></asp:Label> 
       </ItemTemplate> 
      </asp:TemplateField> 
      <asp:TemplateField HeaderText="Edit/Delete"> 
       <ItemTemplate> 
        <asp:LinkButton ID="BtnEdit" runat="server" CausesValidation="false" CommandName="Edit" Text="Edit" /> 
        <span onclick="return confirm ('Are you Sure?')"> 
         <asp:LinkButton ID="BtnDelete" runat="server" CausesValidation="False" CommandName="Delete" Text="Delete" /> 
        </span> 
       </ItemTemplate> 
       <EditItemTemplate> 
        <asp:Button ID="BtnUpdate" runat="server" CausesValidation="true" CommandName="Update" ConflictDetection="OverwriteChanges" Text="Update" ValidationGroup="EnterMatchGridView" /> 
        <asp:Button ID="BtnCancel" runat="server" CausesValidation="false" CommandName="Cancel" ConflictDetection="OverwriteChanges" Text="Cancel" /> 
       </EditItemTemplate> 
      </asp:TemplateField> 
     </Columns> 
    </asp:GridView> 

enter image description here

enter image description here

、どのように私は、このクエリは、行ごとにユニークなMATCH_IDユニークを返す作るのですか?

+1

ちょうど注:あなたの '存在する部分は何もしていません。テーブルが空の場合はFALSE(0)を返します。さもなければTRUE(1)を返します。 –

答えて

2

はそれは...

SELECT s.Match_ID 
    , s.Home_team_ID 
    , s.Away_team_ID 
    , s.Home_team_score 
    , s.Away_team_score 
    , s.Game_date 
    , h.Team_name home_team 
    , a.Team_name away_team 
    FROM MatchStatistics s 
    JOIN Team h 
    ON h.Team_ID = s.Home_team_ID 
    JOIN Team a 
    ON a.Team_ID = s.Away_team_ID 

ではないでしょう???

+0

華麗なああ、ありがとう!私はあなたがそれを行うことができるか分からなかった –

+0

今問題はGridViewを更新しているだけです。自分のチーム名を表示する自宅チームと離脱チームのID列の両方にDropDownListsを作成しました。各IDに値が設定されています。しかし、データソースによって与えられた更新クエリは、 'パラメータ化されたクエリ'(@Match_ID int、@ Home_team_ID int、@ Away_team_ID int、@ Home_team_sc 'は、' @Match_ID 'パラメータを期待しています。パラメータMatch_IDがあるので、なぜこのエラーが出るのか分かりません –

+0

私はASPを知らないので、私は助けることができるとは思っていませんが、質問は問題ではないと確信しています。 – Strawberry

関連する問題