не работает соединение запросов linq с фильтрацией нескольких таблиц - PullRequest
0 голосов
/ 15 сентября 2011

У меня есть форма с четырьмя текстовыми полями и двумя выпадающими списками ...

Я фильтрую данные, и отображение данных в виде таблицы данных зависит от выбора в выпадающем списке и текста, набранного в текстовых полях.

для этого я написал следующий код

private void btnRunreports_Click(object sender, EventArgs e)
{
    int agefrom = Convert.ToInt32(cbGEFrom.Text);
    int ageto = Convert.ToInt32(cbGETo.Text);
    DateTime today = DateTime.Today;
    DateTime max = today.AddYears(-(agefrom + 1));
    DateTime min = today.AddYears(-(ageto));

    string maximum = Convert.ToString(max);
    string minimum = Convert.ToString(min);

    string gender = "";
    gender = Classes.reportmembers.ConvertGender(cbGEGendertype.Text);
    var mems = Classes.reportmembers
                      .getallreportmembers(gender,
                                           cbGEMembershiptype.SelectedText,
                                           txtlastname.Text,
                                           txtpostcode.Text,
                                           txtcardnum.Text,
                                           txtreference.Text,
                                           cbGEStatustype.SelectedText,
                                           maximum, minimum);
    BindingSource bs = new BindingSource();
    bs.DataSource = mems;
    dgvReportMembers.DataSource = bs;
}

, и это мой класс reportmembers:

class ReportMebers
{
    public int MemberID { get; set; }
    public string Lastname { get; set; }
    public string Firstname { get; set; }
    public string Postcode { get; set; }
    public string Reference { get; set; }
    public string CardNum { get; set; }
    public string IsBiometric { get; set; }
    public string DOB { get; set; }
    public string MShipType { get; set; }
    public string StatusType { get; set; }
    public string EndDate { get; set; }
}

 class reportmembers
 {
     public static List<ReportMebers> getallreportmembers(string gender, string membershiptype, string lastname,
                                                    string postcode,string cardnum,string refernce,
                                                      string membershipstatustypesa, string maxage, string minage)
     {

         //CultureInfo provider = CultureInfo.InvariantCulture;
         EclipseEntities eclipse = new EclipseEntities();
        List<ReportMebers> reporall = new List<ReportMebers>();
         var memberreport = from report in eclipse.members
                            join memtomship in eclipse.membertomships on report.member_Id equals memtomship.member_Id
                            join mshoption in eclipse.mshipoptions on memtomship.mshipOption_Id equals mshoption.mshipOption_Id
                            join membershiptypes in eclipse.mshiptypes on mshoption.mshipType_Id equals membershiptypes.mshipType_Id
                            join membershipstatustypes in eclipse.mshipstatustypes on memtomship.mshipStatusType_Id equals membershipstatustypes.mshipStatusType_Id                              
                            where  report.member_Lastname.Equals(lastname)
                            && report.member_CardNum.Equals(cardnum)
                            && report.member_Postcode.Equals(postcode)
                            && report.member_Reference.Equals(refernce)
                            && report.member_Gender.Equals(gender)
                            && membershiptypes.mshipType_Name.Equals(membershiptype)
                            && membershipstatustypes.mshipStatusType_Name.Equals(membershipstatustypesa)
                            && string.Compare(report.member_Dob,maxage) >= 0
                            && string.Compare(report.member_Dob, minage)< 0
                            select new
                            {
                                report.member_Id,
                                report.member_Lastname,
                                report.member_Firstname,
                                report.member_Postcode,
                                report.member_Reference,
                                report.member_CardNum,
                                report.member_IsBiometric,
                                report.member_Dob,
                                membershiptypes.mshipType_Name,
                                membershipstatustypes.mshipStatusType_Name,
                                memtomship.memberToMship_EndDate
                            };
         try
         {
             foreach (var membe in memberreport)
             {

                 ReportMebers allmembersrepor = new ReportMebers();
                 allmembersrepor.MemberID = membe.member_Id;
                 allmembersrepor.Lastname = membe.member_Lastname;
                 allmembersrepor.Firstname = membe.member_Firstname;
                 allmembersrepor.Postcode = membe.member_Postcode;
                 allmembersrepor.Reference = membe.member_Reference;
                 allmembersrepor.CardNum = membe.member_CardNum;
                 allmembersrepor.IsBiometric = membe.member_IsBiometric;
                 allmembersrepor.DOB = membe.member_Dob;
                 allmembersrepor.MShipType = membe.mshipType_Name;
                 allmembersrepor.StatusType = membe.mshipStatusType_Name;
                 allmembersrepor.EndDate = membe.memberToMship_EndDate;
                 reporall.Add(allmembersrepor);

             }
         }
         catch (Exception ex)
         {

             MessageBox.Show(ex.Message);

         }
         return reporall;
     }

, если я введу robin в txtlastname, подробности будут отображатьсяWhoose фамилия Робин ...

Я проверил в базе данных есть человек с фамилией Робин .. но он не отображается в представлении таблицы данных ...

любой парень, пожалуйста, помогитена этом ...

Заранее большое спасибо ....

1 Ответ

0 голосов
/ 15 сентября 2011

Ваша проблема в том, что вы делаете сравнение И по всем полям. Это означает, что возвращаются только записи из базы данных, которые соответствуют ВСЕМ введенным данным! Если вы введете robin только в качестве фамилии и больше ничего, вы не получите результатов, потому что все остальные поля не совпадают. Измените свой запрос, чтобы включить только те поля, которые не являются пустыми. Примерно так:

var query = from report in eclipse.members
            join memtomship in eclipse.membertomships on report.member_Id equals memtomship.member_Id
            join mshoption in eclipse.mshipoptions on memtomship.mshipOption_Id equals mshoption.mshipOption_Id
            join membershiptypes in eclipse.mshiptypes on mshoption.mshipType_Id equals membershiptypes.mshipType_Id
            join membershipstatustypes in eclipse.mshipstatustypes on memtomship.mshipStatusType_Id equals membershipstatustypes.mshipStatusType_Id;

if(!string.IsNullOrEmpty(lastname))
    query = query.Where(r => r.member_Lastname == lastname);
if(!string.IsNullOrEmptry(cardnum)
    query = query.Where(r => r.member_CardNum == cardnum);
// and so on for all parameters
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...