>데이터 베이스 >MySQL 튜토리얼 >Entity Framework를 사용하여 익명 SQL 쿼리 결과를 검색하는 방법은 무엇입니까?

Entity Framework를 사용하여 익명 SQL 쿼리 결과를 검색하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-30 02:36:24632검색

How to Retrieve Anonymous SQL Query Results Using Entity Framework?

Entity Framework에서 익명 SQL 쿼리 결과 검색

Entity Framework는 SqlQuery 원시 SQL을 실행하고 결과를 특정 엔터티에 매핑하는 방법입니다. 그러나 익명 결과를 검색하려면 다른 접근 방식이 필요합니다.

한 가지 해결 방법은 원시 SqlConnection 및 ExecuteReader 메서드를 사용하여 데이터를 검색하고 결과 집합을 기반으로 익명 개체를 수동으로 생성하는 것입니다. 사용할 수 있는 사용자 정의 확장 방법은 다음과 같습니다.

public static IEnumerable<dynamic> DynamicListFromSql(this DbContext db, string Sql, Dictionary<string, object> Params)
{
    using (var cmd = db.Database.Connection.CreateCommand())
    {
        cmd.CommandText = Sql;
        if (cmd.Connection.State != ConnectionState.Open) { cmd.Connection.Open(); }

        foreach (KeyValuePair<string, object> p in Params)
        {
            DbParameter dbParameter = cmd.CreateParameter();
            dbParameter.ParameterName = p.Key;
            dbParameter.Value = p.Value;
            cmd.Parameters.Add(dbParameter);
        }

        using (var dataReader = cmd.ExecuteReader())
        {
            while (dataReader.Read())
            {
                var row = new ExpandoObject() as IDictionary<string, object>;
                for (var fieldCount = 0; fieldCount < dataReader.FieldCount; fieldCount++)
                {
                    row.Add(dataReader.GetName(fieldCount), dataReader[fieldCount]);
                }
                yield return row;
            }
        }
    }
}

이 방법을 사용하면 다음과 같이 SQL 쿼리에서 익명 결과를 검색할 수 있습니다.

List<dynamic> results = DynamicListFromSql(myDb, "select * from table where a=@a and b=@b", new Dictionary<string, object> { { "a", true }, { "b", false } }).ToList();

위 내용은 Entity Framework를 사용하여 익명 SQL 쿼리 결과를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.