it-swarm.com.de

Linq-Abfrage gibt true oder false zurück

Ich habe eine Abfrage, wo TRUE oder FALSE zurückgegeben werden soll. 

var query = from c in db.Emp
            from d in db.EmpDetails 
            where c.ID == d.ID && c.FirstName == "A" && c.LastName == "D" 
          // It should return TRUE when this above statement matches all these conditions

und ich möchte dieses Abfrageergebnis an eine Eigenschaft (vom Datentyp "String")

this.result = Conert.ToBoolean(query);

wie kann ich dies in LINQ erreichen? 

BEARBEITEN:

EmpMapper-Klasse

  public class EmpMapper
  {
    EmpEntities db;
    // ID column already exists in the DB
    private int ID;
    // I am creating this property to add it from the UI side, depending on the certain conditions in the query. That is why I created a separate class to map the existing ID from the DB
    bool result;
    public EmpMapper(int ID, bool result)
    {
      this.db = new EmpEntites();
      this.ID = ID;
      var query = from c in db.Emp
            from d in db.EmpDetails 
            where c.ID == d.ID && c.FirstName == "A" && c.LastName == "D" 
          // It should return TRUE when this above statement matches all these conditions
      this.result = Convert.ToBoolean(query);
    }
   public int ID
   {
    get{return this.ID;}
    set{this.ID = value;}
   }
   public bool result
   {
    get{return this.result;}
    set{this.result = value;}
   }
   } 

MainViewModel-Klasse 

      List<EmpMapper> empMapCol = new List<EmpMapper>();

     private void Page_Loaded(object sender, RoutedEventArgs e)
    {
      var emp_query = from c in db.Emp
                      orderby c.ID
                      select a;
     List<Emp> empCol = emp_query.ToList();
     foreach(Emp item in empCol)
     {
       this.empMapCol.Add(new EmpMapper(item.ID, item.result)); 
     }
     datagrid1.ItemsSource = empMapCol;
     }
     }
12
user1221765

versuche dies,

 var query = (from c in db.Emp
        from d in db.EmpDetails 
        where c.ID == d.ID && c.FirstName == "A" && c.LastName == "D"
         select c 
         ).Any(); 

  this.result = query; //no need to convert to boolean its already bool value
24
Satpal

Wenn ich Sie richtig verstanden habe, möchten Sie true erhalten, wenn eines der Ergebnisse der Abfrage alle Bedingungen erfüllt. In diesem Fall versuchen Sie Folgendes:

var found =
    (from c in db.Emp
    from d in db.EmpDetails
    where c.ID == y.ID && c.FirstName == "A" && c.LastName == "D"
    select c).Any();

this.result = found.ToString();
4
Maciej

Sie können .Any () oder .Count () verwenden. Any () zeigt eine bessere Leistung. (Überprüfen Sie diese SO - Frage , um zu sehen, warum) 

.Irgendein()

var query = from c in db.Emp
            from d in db.EmpDetails 
            where c.ID == d.ID && c.FirstName == "A" && c.LastName == "D" 
          // It should return TRUE when this above statement matches all these conditions
this.result = query.Any().ToString()

.Anzahl()

var query = from c in db.Emp
            from d in db.EmpDetails 
            where c.ID == d.ID && c.FirstName == "A" && c.LastName == "D" 
          // It should return TRUE when this above statement matches all these conditions
this.result = (query.Count() > 0).ToString()
3
Oscar Foley
var query = from c in db.Emp
            from d in db.EmpDetails 
            select new { c.ID == y.ID &&  
                         c.FirstName == "A" && 
                         c.LastName == "D" };
0
Skinny Pipes

Wenn Sie wirklich eine "richtige" oder "falsche" Zeichenfolge wünschen:

    public string result
    {
        get
        {
            return db.Emp.SelectMany(c => db.EmpDetails, (c, d) => new {c, d})
                         .Where(@t => c.ID == y.ID && c.FirstName == "A" && c.LastName == "D")
                         .Select(@t => c)).Any().ToString();
        }
    }

Aber ich würde vorschlagen, die Eigenschaft "result" zu einem bool zu machen und das ToString () zu entfernen. Wenn Sie einen Bool haben, können Sie immer einen ToString () darauf ausführen

0
user2141886