9

これを邪魔にならないようにすることから始めましょう。MSAccessDBを使用しているので、変更できません。

これは正常に機能します。

using (OleDbConnection conn = ConnectionHelper.GetConnection())
{
  conn.Open();
  var results = conn.Query<string>(
    "select FirstName from Students where LastName = @lastName", 
    new { lastName= "Smith" }
  );
  conn.Close();
}

これは正常に機能します。

using (OleDbConnection conn = ConnectionHelper.GetConnection())
{
  OleDbCommand cmd = new OleDbCommand(
    "update Students set FirstName = @firstName, City = @city where LastName = @lastName", 
    conn
  );
  cmd.Parameters.AddWithValue("firstName", "John");
  cmd.Parameters.AddWithValue("city", "SomeCity");
  cmd.Parameters.AddWithValue("lastName", "Smith");

  conn.Open();
  var result = cmd.ExecuteNonQuery();
  conn.Close();
}

これは実行されません...エラーなしで実行されますが、DBではFirstNameが「SomeCity」に設定され、Cityは「John」に設定されます。

using (OleDbConnection conn = ConnectionHelper.GetConnection())
{
  conn.Open();
  var results = conn.Query<string>(
    "update Students set FirstName = @firstName, City = @city where LastName = @lastName", 
    new { firstName = "John", city = "SomeCity", lastName = "Smith" }
  );
  conn.Close();
}

何か案は?

以下の編集

DynamicParametersを使用すると、Dapperが機能します。

using (OleDbConnection conn = ConnectionHelper.GetConnection())
{
  DynamicParameters parameters = new DynamicParameters();
  parameters.Add("firstName", "John");
  parameters.Add("city", "SomeCity");
  parameters.Add("lastName", "Smith");

  conn.Open();
  var result = conn.Query<string>(
    "update Students set FirstName = @firstName, City = @city where LastName = @lastName",
    parameters
  );
  conn.Close();
}
4

2 に答える 2

9

少し掘り下げた後、私は原因を見つけることができました:

以下は、dapperのSqlMapperからのCreateParamInfoGeneratorデリゲートです。

    public static Action<IDbCommand, object> CreateParamInfoGenerator(Identity identity)
    {

        // code above here
        IEnumerable<PropertyInfo> props = type.GetProperties().OrderBy(p => p.Name); 

小道具は、都市を前に移動するOrderBy(p => p.Name)によって並べ替えられる全会一致のパラメータです。

new { firstName = "John", city = "SomeCity", lastName = "Smith" }

次に、順序が重要なIDbCommandパラメーターに小道具が追加されます。

OrderBy()句をコメントアウトすると、すべてが機能します。

また、DynamicParametersをテストし、都市を前もって移動するために属性を意図的に並べ替えました。

        var parameters = new DynamicParameters();
        parameters.Add("city", "SomeCity");
        parameters.Add("firstName", "John");
        parameters.Add("lastName", "Smith");

        var result = dbConnection.Query<string>(
          "update Students set FirstName = @firstName, City = @city where LastName = @lastName",
          parameters
        );

上記はうまく機能しなかったので、属性の順序が理由です!

今のところ、SqlMapperのローカルコピーを変更し、OrderBy()を削除して、Marcからの公式の評決を待つことができると思います...

お役に立てれば。

于 2012-09-08T01:08:25.830 に答える
4

同様の問題が発生しましuse parameter names like @param1, @param2た。@name、@ id、@ priceの代わりに、SQLMapper.csファイルを変更しなくても順序が同じになるようにしました。

何かのようなもの

public void Update(Movie movie)
{
  var sql = "UPDATE myDB.movies set title=@param1, genre=@param2 where ID=@param3";
  db.Execute(sql, new { param1 = movie.Title, param2 = movie.Genre, param3 = movie.ID });
}
于 2014-01-29T07:03:35.550 に答える