1

C#とDapperを使用してplpgsqlで記述されたPostgresqlストアドプロシージャを呼び出そうとしていますが、Dapperがパラメータをストアドプロシージャに挿入する前にアルファベット順に並べ替えていることがわかりました。この動作を回避し、アイテムを正しい順序で挿入する方法はありますか?

たとえば、次の呼び出しは、パラメーター名をアルファベット順に並べるため、正しく実行されません。通話を通過させるには、手動でアルファベット順に並べ替える必要があります。

int map_id = conn.Query<int>(
"insert_color",
new
{
    zebra_name = new DbString { Value = slide_name },
    door_name = new DbString { Value = fov_name },
    foo_number = cycle_number,
    variable_path = new DbString { Value = image_path },
    random_path = new DbString { Value = meta_path },
    x = x,
    y = y,
    z = z,
    exposure = exposure,
    type_name = new DbString { Value = image_type },
    copy = copy
},
commandType: CommandType.StoredProcedure).First();

ストアドプロシージャの宣言は次のとおりです。

CREATE OR REPLACE FUNCTION insert_color(
zebra_name text, door_name text, foo_number integer,    
variable_path text, random_path text, 
x real, y real, z real, exposure real,
type_nametext, copy integer) RETURNS integer AS $$
    ...
$$ LANGUAGE plpgsql;
4

1 に答える 1

1

内部的には、Dapperはリフレクションを使用してparamオブジェクトのプロパティを取得します。具体的には、GetProperies(...)問題は、それらが特定の順序であることが保証されていないということです...

GetPropertiesメソッドは、アルファベット順や宣言順など、特定の順序でプロパティを返しません。順序は異なるため、コードはプロパティが返される順序に依存してはなりません。

ある程度役立つように、パラメータをアルファベット順に並べることを選択しましたが、残念ながら、クラスにある順序でパラメータが表示されるようにする方法はありません。

于 2012-07-31T20:40:28.737 に答える