3

アクセス用のストアド プロシージャを公開している既存の SQL Server データベースに対して OrmLite を使用しています。これらの SP の 1 つは 3 つの int パラメーターを取りますが、いずれかが null になることを想定しています。ただし、オプションとして宣言されているパラメーターはありません。

私が試したコードは次のとおりです。

        using (IDbConnection scon = myFactory.OpenDbConnection())
        {
            rowCount = scon.SqlScalar<int>("EXEC myProc @FileID, @FileTypeID, @POID",
            new
            {
                FileID = req.FileId,
                FileTypeID = (int?)null,
                POID = req.PoId,
            });
        }

しかし、これは SqlException を生成します: スカラー変数 "@FileTypeID" を宣言する必要があります。内部で SQLParameterCollection を調べると、OrmLite によって生成されているパラメーターは 2 つだけであることがわかります。

この SP を null パラメータで呼び出すことはできますか?

4

1 に答える 1

2

SqlScalar ではサポートされていません。コードを見ると、クラス ServiceStack.OrmLite.OrmLiteReadExtensions の SqlScalar メソッドが SetParameters メソッドを実行し、2 番目のパラメーター (excludeNulls) が true に等しいクエリにパラメーターを追加する役割を果たしていることがわかります。 )。
それを修正したい場合は、すべての SqlScalar メソッドを変更して SetParameters を true で呼び出す必要があり、SetParameters メソッドは次のようになります (null 以外の DBNull.Value をサポートする必要があります)。

private static void SetParameters(this IDbCommand dbCmd, object anonType, bool excludeNulls)
    {
        dbCmd.Parameters.Clear();
        lastQueryType = null;
        if (anonType == null) return;

        var pis = anonType.GetType().GetSerializableProperties();
        foreach (var pi in pis)
        {
            var mi = pi.GetGetMethod();
            if (mi == null) continue;

            var value = mi.Invoke(anonType, new object[0]);
            if (excludeNulls && value == null) continue;

            var p = dbCmd.CreateParameter();
            p.ParameterName = pi.Name;
            p.DbType = OrmLiteConfig.DialectProvider.GetColumnDbType(pi.PropertyType);
            p.Direction = ParameterDirection.Input;
            p.Value = value ?? DBNull.Value; // I HAVE CHANGED THAT LINE ONLY
            dbCmd.Parameters.Add(p);
        }
    }

コードを変更すると、次の方法でパラメーターに null を設定できます。

var result = db.SqlScalar<int>("EXEC DummyScalar @Times", new { Times = (int?)null });

私の意見では、あなたはそれを github の欠陥として説明することができ、私はプル リクエストを行うことができます。

于 2013-07-04T05:44:28.860 に答える