Comment obtenir la valeur de la colonne dynamiquement à l'aide de Dapper

dapper

Question

En utilisant Dapper, comment puis-je obtenir la valeur d'une colonne dans une table de manière dynamique?

Ce que j'ai:

string tableName = "Table1";
int itemId = 1;
string columName = "MyBitColumn";

var query = string.Format("select {0} from {1} where {1}Id = @itemId", columnName, tableName);
var entity = conn.Query(query, new { itemId }).FirstOrDefault();

// I'd like something like this...
bool val = entity[columnName] as bool; // returns true or false, given that "MyBitColumn" is a bit in my sql db

Merci!

Réponse acceptée

Vous pouvez convertir l'entité en IDictionary<string, object> et accéder par nom:

var entity = (IDictionary<string, object>) ... // your code
if((bool)entity[column name]) { ... }


Sous licence: CC-BY-SA with attribution
Non affilié à Stack Overflow
Sous licence: CC-BY-SA with attribution
Non affilié à Stack Overflow