-1

ボタンクリック時の私のC#コードは次のとおりです。

                Int32 fileLen;

            fileLen = uplImage.PostedFile.ContentLength;


            Byte[] input = new Byte[fileLen];

            myStream = uplImage.FileContent;

            myStream.Read(input, 0, fileLen);

            DALBio bio = new DALBio();
            bio.PlayerID = Session["playerID"].ToString();
            bio.Pending = 'Y';
            bio.Photo = input;
            DALBio.insertImage(bio);

ストアド プロシージャを呼び出す C# コードを次に示します。

public static bool insertImage(DALBio bio)
{
    string sql = string.Format("EXECUTE insertPlayerImage @playerID = '{0}', @profileImage = '{1}', @pending = '{2}'", bio.playerID, bio.Photo, bio.pending);

    SqlCommand insertPhoto = new SqlCommand(sql, baseballConnection);

    try
    {
        baseballConnection.Open();
        insertPhoto.ExecuteNonQuery();
        return true;
    }
    catch
    {
        return false;
    }
    finally
    {
        baseballConnection.Close();
    }
}

次のエラーが表示されます: データ型 varchar から varbinary(max) への暗黙的な変換は許可されていません。CONVERT 関数を使用して、このクエリを実行します。

だから私はストアドプロシージャを次のように変更しようとしました:

ALTER PROCEDURE insertPlayerImage @playerID varchar(9), @profileImage varchar(max), @pending char(1)
AS

CONVERT(varbinary(max), @profileImage)

INSERT INTO PlayerImage(
playerID,profileImage, pending)
VALUES(
@playerID, @profileImage, @pending)
GO

そして、変換行が好きではありません。本当に何をすべきかわからない。

4

1 に答える 1

-1

これを試して :-

alter PROCEDURE insertPlayerImage (@playerID varchar(9), @profileImage varchar(max), @pending char(1))

なので

SET @profileImage = CONVERT(varbinary(max), @profileImage)

于 2013-05-15T19:09:06.483 に答える