C# 使用c从Oracle 11g保存和检索.avi文件#
我想使用c#和Oracle 11g将.avi文件保存在数据库的表中 这张桌子很简单C# 使用c从Oracle 11g保存和检索.avi文件#,c#,oracle,stored-procedures,oracle11g,blob,C#,Oracle,Stored Procedures,Oracle11g,Blob,我想使用c#和Oracle 11g将.avi文件保存在数据库的表中 这张桌子很简单 CREATE TABLE VIDEOS ( id number, description varchar2(20), video ORDSYS.OrdVideo ); 我正在做的事情是在c中使用一个表单#获取一些字段并从Oracle db调用一个过程 程序是 create or replace procedure inserareVideoBD(vid in number, vdescr
CREATE TABLE VIDEOS
(
id number,
description varchar2(20),
video ORDSYS.OrdVideo
);
我正在做的事情是在c中使用一个表单#获取一些字段并从Oracle db调用一个过程
程序是
create or replace
procedure inserareVideoBD(vid in number, vdescriere in varchar2, nfis in varchar2 )
is
begin
declare
obj ORDSYS.ORDVideo;
ctx RAW (64):=NULL;
begin
insert into videos values (vid, vdescriere, ordsys.ordvideo.init('FILE', 'DIR', nfis));
commit;
end;
end;
//提到DIR文件已经分配,db可以访问它,因为我保存的图像的工作方式几乎相同
因此,在视频保存后,我想使用以下步骤检索它
create or replace
procedure FETCHERVIDEO (vid in number, flux out blob, descriere out varchar2)
is
begin
declare
obj ordsys.ordvideo;
mimeType VARCHAR2(4000);
format VARCHAR2(31);
ctx RAW(64) :=NULL;
begin
select video into obj from videos where id=vid;
DBMS_LOB.CREATETEMPORARY(flux, true, 10);
obj.getContentInLob(ctx,flux, mimeType,format);
select description into descriere from videos where id=vid;
end;
end;
保存视频后,我想使用windows media player播放它。这就是我们想要实现的代码
OracleCommand cmd1 = new OracleCommand("fetchervideo", con);
cmd1.CommandType = CommandType.StoredProcedure;
cmd1.Parameters.Add("vid", OracleDbType.Int32);
cmd1.Parameters.Add("flux", OracleDbType.Blob);
cmd1.Parameters.Add("descriere", OracleDbType.Varchar2, 255);
cmd1.Parameters[0].Direction = ParameterDirection.Input;
cmd1.Parameters[1].Direction = ParameterDirection.Output;
cmd1.Parameters[2].Direction = ParameterDirection.Output;
//get video id
cmd1.Parameters[0].Value = Convert.ToInt32(comboBox1.SelectedItem);
try { cmd1.ExecuteScalar(); }
catch (OracleException exc) { Mesaj2.Text = "Mesaj: " + exc.Message; }
OracleBlob var = (OracleBlob)cmd1.Parameters[1].Value;
byte[] blob = new Byte[var.Length];
File.WriteAllBytes(@"c://temp_mvi.avi", blob);
try
{
player.URL = "c://temp_mvi.avi";
player.Ctlcontrols.play();
}
问题是,文件保存在指定的路径,但当上载的原始文件在同一播放机上播放时,无法播放该文件 我错过了什么吗?谁能给我一些更好的主意。
非常感谢您的每一个回复 如果您使用的是web应用程序,我认为您需要在html端指定内容类型,以便它可以相应地显示内容