Chamadas de método local
Uma chamada de método local é aquela que é executada dentro do modelo de objeto. Uma chamada de método remoto é aquela que o LINQ to SQL traduz para SQL e transmite para o mecanismo de banco de dados para execução. As chamadas de método local são necessárias quando o LINQ to SQL não pode traduzir a chamada em SQL. Caso contrário, um InvalidOperationException é jogado.
Exemplo 1
No exemplo a seguir, uma Order
classe é mapeada para a tabela Orders no banco de dados de exemplo Northwind. Um método de instância local foi adicionado à classe.
Na Consulta 1, o construtor da Order
classe é executado localmente. Na Consulta 2, se o LINQ to SQL tentasse traduzir LocalInstanceMethod()
para SQL, a tentativa falharia e uma InvalidOperationException exceção seria lançada. Mas como o LINQ to SQL fornece suporte para chamadas de método local, o Query2 não lançará uma exceção.
// Query 1.
var q1 =
from ord in db.Orders
where ord.EmployeeID == 9
select ord;
foreach (var ordObj in q1)
{
Console.WriteLine("{0}, {1}", ordObj.OrderID,
ordObj.ShipVia.Value);
}
' Query 1.
Dim q0 = _
From ord In db.Orders _
Where ord.EmployeeID = 9 _
Select ord
For Each ordObj In q0
Console.WriteLine("{0}, {1}", ordObj.OrderID, _
ordObj.ShipVia.Value)
Next
// Query 2.
public int LocalInstanceMethod(int x)
{
return x + 1;
}
void q2()
{
var q2 =
from ord in db.Orders
where ord.EmployeeID == 9
select new
{
member0 = ord.OrderID,
member1 = ord.LocalInstanceMethod(ord.ShipVia.Value)
};
}
' Query 2.
Public Function LocalInstanceMethod(ByVal x As Integer) As Integer
Return x + 1
End Function
Sub q2()
Dim db As New Northwnd("")
Dim q2 = _
From ord In db.Orders _
Where ord.EmployeeID = 9 _
Select member0 = ord.OrderID, member1 = ord.LocalInstanceMethod(ord.ShipVia.Value)
End Sub