Where expression with .All (and this one also containing .All) generates invalid query
Posted: Mon  26 Aug 2019 08:01
				
				In this example the Where expression has been replaced by a FirstOrDefault expression.
Invalid query:
Database Provider: Devart.Data.Oracle.EFCore version 9.7.805
A repository reproducing the issue can be found here: https://github.com/janmeyns/devart-efco ... ug-repro-2
			Code: Select all
// This doesn't - throws ORA-00936: missing expression
                    var classroomResult2 = context
                        .Set<Classroom>()
                        .FirstOrDefault(_ => _.PuzzleGroups.All(gr => gr.Puzzles.All(p => p.Completed)));                        
Code: Select all
SELECT
	 "_".ID,
	 "_".NAME
FROM CLASSROOM "_"
WHERE NOT EXISTS (
	
    SELECT
		 1
    
	FROM PUZZLE_GROUP "gr"
    
	WHERE (
		"_".ID = "gr".CLASSROOM_ID)
	 AND
		 (
			NOT (
				SELECT
					 CASE
        WHEN NOT EXISTS (
						
            SELECT
							 1
            
						FROM PUZZLE "p"
            
						WHERE (
							"gr".ID = "p".PUZZLE_GROUP_ID)
						 AND
							 (
								"p".COMPLETED = 0)
							)
						
        THEN 1 ELSE 0
    END
    
					FROM DUAL)
				)
			)
		
FETCH FIRST 1 ROWS ONLY
Database Provider: Devart.Data.Oracle.EFCore version 9.7.805
A repository reproducing the issue can be found here: https://github.com/janmeyns/devart-efco ... ug-repro-2