As far as I know there are two ways:
1) Creates the expression lambda expression
(Linq
) in return Iqueryable and another variable SQlExecutar
perform a Tolist(). In the variable with return Iqueryable has the SQL generated.
In this code shown, when passing the instruction SQL.ToList()
above the variable SQL
will show the SELECT
generated:
using (GenericsEntities db = new GenericsEntities())
{
//Quando a variável "SQL" der um ToList() ela mostrado a "SELECT"
IQueryable<Tipos> SQL = db.Tipos.AsQueryable();
IList<Tipos> SQLExecutar = SQL.ToList();
}
data:image/s3,"s3://crabby-images/f6363/f6363abc2924039d61bde0295a384c183440d2bb" alt="inserir a descrição da imagem aqui"
One way to visualize this is also with Breakpoint with F11 in the window Intellitrace see the output, Observer:
data:image/s3,"s3://crabby-images/8b495/8b4953acbefd59813143ebcbbe0e3f0d40e7176f" alt="inserir a descrição da imagem aqui"
2) In the version EPH 6+, there is a Action responsible for this by having a way out of all the information from connection and the Sqls. The Database.Log redeems such information with the encoding below. I create a Function that has a type parameter String that receives the data and prints on the console screen.
using (GenericsEntities db = new GenericsEntities())
{
db.Database.Log = StrRestult => fs(StrRestult);
IQueryable<Tipos> SQL = db.Tipos.AsQueryable();
IList<Tipos> SQLExecutar = SQL.ToList();
}
//função que irá imprimir na tela (console) tudo o que
//aconteceu nas instruções de conexão e SQLs geradas
private static void fs(string StrRestult)
{
System.Console.WriteLine(StrRestult);
}
data:image/s3,"s3://crabby-images/44d12/44d12ee5c1dcd734db00dd4172a0167549e0c948" alt="inserir a descrição da imagem aqui"
It is very useful as a way to debug and visualize how it works internally.
The second option is the most effective, because I can also visualize Insert
, Delete
, Update
and Select
very clearly.