查询日期范围

时间:2013-02-26 18:55:21

标签: c# asp.net .net linq entity-framework

我想知道如何在此示例中进行查询:

我有一个具有UserID,UserName,DateRegistered和角色的用户表。 我想通过选择的两个组合框进行查询,每个组合都有: -Period注册用户(当月,上个月,当前15天,过去15天,今年和去年) -Roles(不同的角色)

我想在网格中显示引用所选combobox项的结果查询。 例如:用户在过去15天内注册了状态管理员。

我知道如何做到这一点,但我想做一些通用的事情,而不是根据期间做很多查询。 我使用EntityFramework。

这不是代码只是我想它应该是的一个例子,因为我不知道转换periode以及如何比较以防万一不是当前的最后15天。

    string period = dropDownList.SelectedValue.ToString();
    DateTime StarPeriode= new DateTime();
    switch (option.ToUpper())
    {
        case "0":
            // CURRENT 15 days
            StarPeriode = DateTime.Now.Subtract(-15);
            break;
        case "1":
            // LAST 15 days
            StarPeriode = DateTime.Now.Subtract(-30);
            break;
        case "2":
            // CURRENT MONTH
            break;
        case "3":
            // LAST MONTH
            break;
        case "4":
            // CURRENT YEAR
            break;
        case "5":
            // LAST YEAR
            break;
        default:
            break;
    }



    var _db = new Project.Models.UserContext();
    IQueryable<User> query = _db.User.GetUser;

    query = query.Where(p => p.User.RegisterDate <= StarPeriode ||        p.User.RegisterDate>DateTime.Now);

1 个答案:

答案 0 :(得分:0)

在每种情况下设置一个startDate和endDate变量,然后在LINQ语句中使用相同的where子句

var startDate = DateTime.Today;
var endDate = DateTime.Today;
var now = DateTime.Today;

switch (option.ToUpper())
{
    case "0":
        // CURRENT 15 days
        startDate = now.AddDays(-15);
        endDate = now;
        break;
    case "1":
        // LAST 30 days
        startDate = now.AddDays(-30);
        endDate = now;
        break;
    case "2":
        // CURRENT MONTH
        startDate = new DateTime(now.Year, now.Month, 1);
        endDate = new DateTime(now.Year, now.Month, DateTime.DaysInMonth(now.Year, now.Month));
        break;
    case "3":
        // LAST MONTH
        var lastMonth = now.AddMonths(-1);
        startDate = new DateTime(lastMonth.Year, lastMonth.Month, 1);
        endDate = new DateTime(lastMonth.Year, lastMonth.Month, DateTime.DaysInMonth(lastMonth.Year, lastMonth.Month));
        break;
    case "4":
        // CURRENT YEAR
        startDate = new DateTime(now.Year, 1, 1);
        endDate = new  DateTime(now.Year, 12, 31);
        break;
    case "5":
        // LAST YEAR
        var lastYear = now.AddYears(-1);
        startDate = new DateTime(lastYear.Year, 1, 1);
        endDate = new  DateTime(lastYear.Year, 12, 31);
        break;
    default:
        break;
}

var users = Users.Where(u => u.RegisterDate >= startDate && u.RegisterDate <= endDate);

根据您存储RegisterDate值的方式,您需要观察边缘情况,因为我的示例假设所有时间部分都是凌晨12:00:00。