html - SQL 按日期显示每个任务的最新记录

标签 html mysql date sqldatasource sqlcommand

我想为每个任务显示最近更新的记录。 目前,无论执行什么任务,我都只能获取所有记录中的最新记录。

这是前端代码

<asp:SqlDataSource ID="GrabAssignedTasks" runat="server" ConnectionString="<%$ ConnectionStrings:DefaultConnection %>" 
            SelectCommand="SELECT Backlog.Story, Tasks.Task, Tasks.EstimatedHours, Tasks.UserStoryTaskID, Tasks_Log.TaskLogID, Tasks_Log.HoursLeft, Tasks_Log.ModifiedDate 
             FROM Backlog 
             INNER JOIN Tasks ON Backlog.UserStoryID = Tasks.UserStoryID 
             INNER JOIN Tasks_Log ON Tasks.UserStoryTaskID = Tasks_Log.TaskID 
             WHERE (Tasks.OwnershipID = @UserID) AND (Tasks_Log.ModifiedDate = (SELECT MAX(ModifiedDate) AS Expr1 
            FROM Tasks_Log AS Tasks_Log_1))">
            <SelectParameters>
                <asp:SessionParameter Name="UserID" SessionField="loggedInUser" />
            </SelectParameters>
        </asp:SqlDataSource>



    </div>
       <header class="jumbotron hero-spacer">

         <asp:Button ID="BackToTasks" runat="server" Text="Back" OnClick="BackToTasks_Click" CssClass="btn btn-primary btn-large" />


        <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataSourceID="GrabAssignedTasks" Height="179px" Width="829px" OnSelectedIndexChanged="HoursChange_SelectedIndexChanged">
            <Columns>
                <asp:BoundField DataField="Story" HeaderText="Story" SortExpression="Story" />
                <asp:BoundField DataField="Task" HeaderText="Task" SortExpression="Task" />
                <asp:BoundField DataField="EstimatedHours" HeaderText="Estimated Hours" SortExpression="EstimatedHours" />
                <asp:BoundField DataField="UserStoryTaskID" HeaderText="UserStoryTaskID" SortExpression="UserStoryTaskID" InsertVisible="False" ReadOnly="True" HeaderStyle-CssClass="hidden-field" ItemStyle-CssClass="hidden-field"/>
                <asp:BoundField DataField="TaskLogID" HeaderText="TaskLogID" SortExpression="TaskLogID" InsertVisible="False" ReadOnly="True" HeaderStyle-CssClass="hidden-field" ItemStyle-CssClass="hidden-field"/>
                <asp:BoundField DataField="HoursLeft" HeaderText="Hours Left" SortExpression="HoursLeft" />
                <asp:BoundField DataField="ModifiedDate" HeaderText="Last Updated" SortExpression="ModifiedDate" />
                <asp:CommandField ShowSelectButton="True" />
            </Columns>
        </asp:GridView>
        </header>

我在 C# 代码中对此没有任何具体说明。

这是我正在使用的数据库中表的图片。 Database table

最佳答案

您没有将表 Tasks_Log 与 Tasks_Log_1 结合起来,因此无论任务如何,只会返回 Tasks_Log 中修改日期匹配“30/11/2015”的条目。在 Tasks_Log_1 的 WHERE 子句中添加一个条目,以确保您也在正确的 TaskID 上进行匹配:

SELECT Backlog.Story, Tasks.Task, Tasks.EstimatedHours, Tasks.UserStoryTaskID, Tasks_Log.TaskLogID, Tasks_Log.HoursLeft, Tasks_Log.ModifiedDate 
    FROM Backlog 
    INNER JOIN Tasks ON Backlog.UserStoryID = Tasks.UserStoryID 
    INNER JOIN Tasks_Log ON Tasks.UserStoryTaskID = Tasks_Log.TaskID 
    WHERE (Tasks.OwnershipID = @UserID)
    AND (Tasks_Log.ModifiedDate = 
        (SELECT MAX(ModifiedDate) 
         FROM Tasks_Log AS Tasks_Log_1
         WHERE Tasks_Log_1.TaskID = Tasks_Log.TaskID))

关于html - SQL 按日期显示每个任务的最新记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34006855/

相关文章:

html - 在 HTML Canvas 中居中形状

mysql - SQL 查询更新具有时间依赖性的表

javascript - 对于输入类型=日期,将日期显示为 dd-mm-yyyy 格式

mysql - 将出生日期存储在数据库中作为 UNIX 时间?

javascript - 如何在 Angular 4 中使用 *ngFor 实现自定义过滤器管道?

javascript - 表单提交不起作用

html - 滑动下拉不能完美工作

mysql - 如何使用 Ruby on Rails 网站中的此搜索功能避免 SQL 注入(inject)?

c# - 单击按钮时访问 GridView 的数据

java - 如何获取sql表中显示的日期格式?