未処理SQLクエリとEntity Frameworkコア

asp.net-core asp.net-core-mvc c# entity-framework-core

質問

私はASP.NET MVCコアとEntity Frameworkコアに私のアプリケーションを移行し、私は問題を発見した。私はこのようなエンティティへの生のSQLクエリを持っています

var rawSQL = dbContext.Database.SqlQuery<SomeModel>("Raw SQL Query").ToList();

しかし、 SqlQuery<T>context.Databaseにありません。この問題の解決法はありますか?

受け入れられた回答

using Microsoft.Data.Entity;using Microsoft.Data.Entity;して追加することを確認してくださいusing Microsoft.Data.Entity;あなたが使用できる拡張方法があるからです。

var rawSQL = dbContext.SomeModels.FromSql("your SQL");

さらに、SQLインジェクション攻撃の危険性がある生のSQLを使用する代わりに、このFromSqlメソッドを使用すると、次のようなパラメータ化されたクエリを使用できます。

dbContext.SomeModels.FromSql("SELECT * FROM dbo.Blogs WHERE Name = @p0", blogName);


Related

ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ
ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ