Дополнительная информация: ORA-01460: запрошено невыполненное или необоснованное преобразование - PullRequest
0 голосов
/ 10 сентября 2018

Я пытаюсь загрузить изображение в свою базу данных оракула, я пытаюсь загрузить изображение из отправки формы. Без загрузки изображения все работает отлично. когда я загружаю изображение, я получаю "Additional information: ORA-01460: unimplemented or unreasonable conversion requested"

Позвольте мне объяснить мой код:

Вот мой контроллер:

public ActionResult SaveUser(string oid, string fname, string uname, string pass, string pass2, string bt, HttpPostedFileBase image)
        {


            string iuser = Session["UserID"].ToString();
            string fileName = Path.GetFileName(image.FileName);
            String fileExtension = Path.GetExtension(fileName);
            int fileSize = image.ContentLength;


            Stream stream = image.InputStream;
            BinaryReader binaryReader = new BinaryReader(stream);
            byte[] bytes = binaryReader.ReadBytes((int)stream.Length);



            if (pass == pass2)
            {
                if (bt == "0")
                {
                    string packge = "tflhr.pro_new_user.insert_data";
                    _clsDataAccess.package_user(packge, fname, uname, pass, bytes , iuser );

                }
                else if (bt == "1")
                {
                    strComm = "update tflhr.T_USER set USER_NAME='" + fname + "',USER_ENID= '" + uname + "',USER_PASS='" + pass + "',EUSER='"+ iuser + "',IMAGE='" + bytes + "' where OID ='" + oid + "'";
                    _clsDataAccess.read_data(strComm);
                }
            }

            return RedirectToAction("User", new { cpid = 0, bt = 0 });
        }

Вот класс:

   public DataSet package_user(string package, string fname, string pass, string uname, byte[] bytes, string iuser)
        {


            conn = new OracleConnection(clsConnection.ConnectionSave);
            conn.Open();
            cmd = new OracleCommand(package, conn);
            cmd.CommandType = CommandType.StoredProcedure;

            cmd.Parameters.Add("cur_c1", OracleType.Cursor).Direction = ParameterDirection.Output;
            cmd.Parameters.Add("user_name", OracleType.VarChar).Value = fname;
            cmd.Parameters.Add("user_pass", OracleType.VarChar).Value = pass;
            cmd.Parameters.Add("user_enid", OracleType.VarChar).Value = uname;
            cmd.Parameters.Add("bytes", OracleType.Blob).Value = bytes;
            cmd.Parameters.Add("iuser", OracleType.VarChar).Value = iuser;
            cmd.Parameters.Add("euser", OracleType.VarChar).Value = iuser;


            oda = new OracleDataAdapter(cmd);
            ds = new DataSet();

            conn.Close();
            oda.Fill(ds);
            return ds;

        }

Вот процедура:

CREATE OR REPLACE PACKAGE BODY TFLHR.pro_new_user as
procedure insert_data (cur_c1 out t_cursor, user_name in varchar2, user_pass in varchar2,
user_enid in varchar2, bytes in blob, iuser in varchar2, euser in varchar2)
is
code varchar2(5);
begin
select nvl(max(to_number(user_text)),0)+1 into code from tflhr.t_user;
insert into tflhr.t_user (oid, user_text, user_name, user_pass, user_enid,image, iuser, euser,user_path)
values
('USERx'||lpad(code,5,'0'), lpad(code,5,'0'), user_name, user_pass, user_enid, bytes, iuser, euser, lpad(code,5,'0'));
open cur_c1 for
select '1' from dual;
        commit;
    end insert_data;
end;
/

Но я получаю эту ошибку при загрузке изображения: ORA-01460: unimplemented or unreasonable conversion requested

Пожалуйста, помогите мне разобраться с этой проблемой. Порекомендуйте мне подходящую ссылку. Спасибо

...