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;