Udostępnij za pośrednictwem


Instrukcje: Wykonywanie zapytania, które zwraca wyniki PrimitiveType

W tym temacie pokazano, jak wykonać polecenie względem modelu koncepcyjnego przy użyciu EntityCommandelementu , oraz jak pobrać PrimitiveType wyniki przy użyciu elementu EntityDataReader.

Aby uruchomić kod w tym przykładzie

  1. Dodaj model AdventureWorks Sales Do projektu i skonfiguruj projekt tak, aby korzystał z programu Entity Framework. Aby uzyskać więcej informacji, zobacz How to: Use the Entity Data Model Wizard (Instrukcje: korzystanie z Kreatora modelu danych jednostki).

  2. Na stronie kodowej aplikacji dodaj następujące using dyrektywy (Imports w Visual Basic):

    using System;
    using System.Collections.Generic;
    using System.Collections;
    using System.Data.Common;
    using System.Data;
    using System.IO;
    using System.Data.SqlClient;
    using System.Data.EntityClient;
    using System.Data.Metadata.Edm;
    
    Imports System.Collections.Generic
    Imports System.Collections
    Imports System.Data.Common
    Imports System.Data
    Imports System.IO
    Imports System.Data.SqlClient
    Imports System.Data.EntityClient
    Imports System.Data.Metadata.Edm
    
    

Przykład

W tym przykładzie jest wykonywane zapytanie zwracające PrimitiveType wynik. Jeśli przekażesz następujące zapytanie jako argument do ExecutePrimitiveTypeQuery funkcji, funkcja wyświetli średnią cenę katalogową wszystkich Productselementów :

SELECT VALUE AVG(p.ListPrice) FROM AdventureWorksEntities.Products as p

Jeśli przekażesz zapytanie sparametryzowane, podobnie jak poniżej, EntityParameter obiekty do Parameters właściwości obiektu EntityCommand .

CASE WHEN AVG({@score1,@score2,@score3}) < @total THEN TRUE ELSE FALSE END
static void ExecutePrimitiveTypeQuery(string esqlQuery)
{
    if (esqlQuery.Length == 0)
    {
        Console.WriteLine("The query string is empty.");
        return;
    }

    using (EntityConnection conn =
        new EntityConnection("name=AdventureWorksEntities"))
    {
        conn.Open();

        // Create an EntityCommand.
        using (EntityCommand cmd = conn.CreateCommand())
        {
            cmd.CommandText = esqlQuery;
            // Execute the command.
            using (EntityDataReader rdr =
                cmd.ExecuteReader(CommandBehavior.SequentialAccess))
            {
                // Start reading results.
                while (rdr.Read())
                {
                    IExtendedDataRecord record = rdr as IExtendedDataRecord;
                    // For PrimitiveType
                    // the record contains exactly one field.
                    int fieldIndex = 0;
                    Console.WriteLine("Value: " + record.GetValue(fieldIndex));
                }
            }
        }
        conn.Close();
    }
}
Private Shared Sub ExecutePrimitiveTypeQuery(ByVal esqlQuery As String)
    If esqlQuery.Length = 0 Then
        Console.WriteLine("The query string is empty.")
        Exit Sub
    End If

    Using conn As New EntityConnection("name=AdventureWorksEntities")
        conn.Open()

        ' Create an EntityCommand. 
        Using cmd As EntityCommand = conn.CreateCommand()
            cmd.CommandText = esqlQuery
            ' Execute the command. 
            Using rdr As EntityDataReader = cmd.ExecuteReader(CommandBehavior.SequentialAccess)
                ' Start reading results. 
                While rdr.Read()
                    Dim record As IExtendedDataRecord = TryCast(rdr, IExtendedDataRecord)
                    ' For PrimitiveType 
                    ' the record contains exactly one field. 
                    Dim fieldIndex As Integer = 0
                    Console.WriteLine("Value: " & record.GetValue(fieldIndex))
                End While
            End Using
        End Using
        conn.Close()
    End Using
End Sub

Zobacz też