Comment exécuter des requêtes Dapper/MySql en C# à l'aide de variables définies par l'utilisateur
<p>J'ai essayé d'exécuter ce code : </p>
<pre class="brush:php;toolbar:false;">en utilisant le système ;
en utilisant Dapper ;
en utilisant MySql.Data.MySqlClient ;
espace de noms DapperTests
{
Programme de classe
{
static void Main(string[] arguments)
{
en utilisant (var db = new MySqlConnection (@"mysql_connstr_here"))
{
var sql = @"
set @foo := (sélectionnez count(*) dans la table1);
sélectionnez table2.*, @foo de table2;";
var résultat = db.Query(sql);
}
Console.ReadLine();
}
}
}</pré>
<p>Mais j'obtiens l'exception suivante :</p>
<pre class="brush:php;toolbar:false;">System.NullReferenceException : 'La référence de l'objet n'est pas définie sur une instance de l'objet. '
Cette exception est initialement levée dans cette pile d'appels :
MySql.Data.MySqlClient.MySqlConnection.Reader.set(MySql.Data.MySqlClient.MySqlDataReader)</pre>
<p>Mon hypothèse initiale était que la variable était traitée comme un SqlParameter, et comme je ne transmettais aucun paramètre, mon code a échoué.
Existe-t-il un moyen d'exécuter une requête comme celle-ci en utilisant Dapper ? </p>