Mysql
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> Mysql

Cột không xác định 'Project2.Name' trong 'mệnh đề where'

Để xem. Bạn có một truy vấn LINQ to Entities hoàn toàn hợp lệ, nó hoạt động với nhà cung cấp SqlServer và không hoạt động với nhà cung cấp MySQL. Nghe có vẻ giống như một lỗi của nhà cung cấp MySQL đối với tôi, nó còn có thể là gì nữa? Nhưng cái nào? Tôi không hiểu cách đó hữu ích như thế nào, nhưng hãy đặt cược của tôi vào # 78610 (được khởi xướng bởi ASP MVC MsSql di chuyển sang MySQL SO đăng), được đánh dấu là trùng lặp với # 76663 . Hoặc # 77543 vv

Vì vậy, trình kết nối MySQL có vấn đề với OrderBy trong các truy vấn con. Để giải quyết vấn đề, tôi có thể đề xuất (khi có thể) cách thay thế để triển khai MaxBy , tức là (trong mã giả) thay vì seq.OrderByDescending(col).FirstOrDefault() sử dụng seq.FirstOrDefault(col == seq.Max(col)) mẫu hoạt động:

var Result = ctx.Items
    .Where(x => x.Contact.Country == Country)
    .GroupBy(p => p.Name)
    .Where(g => !g.Any(x => x.Value == "X"))
    .Select(g => g.FirstOrDefault(e => e.Date == g.Max(e1 => e1.Date)))
    .ToList();


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. SQL / Laravel - Tại sao truy vấn của tôi trả về một tập hợp trống?

  2. Khóa cấp hàng MySQL

  3. Làm cách nào tôi có thể làm sạch các bảng tạm thời trên mysql

  4. Tại sao từ khóa đã nhập không được lưu trữ trong cơ sở dữ liệu?

  5. MySQL Event If Statement END IF Error