读书人

存取BLOB型速度太慢,该怎么处理

发布时间: 2012-02-16 21:30:36 作者: rapoo

存取BLOB型速度太慢
GetFileOpenName("插入文件",filepath,filename,"doc","文件(*.*), *.*")
If Len(filepath)=0 Then
Return
End If

long row
row=dw_1.insertrow(dw_1.rowcount()+1)
dw_1.setitem(row,"cou_id",jb)
dw_1.setitem(row,"sort1",filename)
dw_1.scrolltorow(row)
dw_1.setrow(row)
dw_1.setfocus()

if dw_1.update()=1 then
commit using sqlca;
else
rollback using sqlca;
end if
setpointer(arrow!)

ll_row=dw_1.getrow()
aa=string(dw_1.object.cou_id[ll_row])
bb=string(dw_1.object.id[ll_row])

If ole_1.InsertFile(filepath)<>0 Then
Return
End If
Blb_tmp=ole_1.ObjectData

UPDATEBLOB tms_cou_image SET book=:blb_tmp
WHERE cou_id=:aa and id=:bb
USING SQLCA;
有有的方法把PPT或EXCEL存入到中,或者可以我化一下我的句,!

[解决办法]
不知你要做什么,又是保存,又是读取,又是保存的!


可改成
long row
row=dw_1.insertrow(0)
dw_1.setitem(row,"cou_id",jb)
dw_1.setitem(row,"sort1",filename)

bb=string(dw_1.object.id[row])

if dw_1.update()=1 then
UPDATEBLOB tms_cou_image SET book=:blb_tmp
WHERE cou_id=:jb and id=:bb ;
if sqlca.sqlcode = 0 then

commit using sqlca;
else
rollback using sqlca;
end if
else


rollback using sqlca;
end if

[解决办法]
把那句加上了,也可以直接读取文件

GetFileOpenName("插入文件",filepath,filename,"doc","文件(*.*), *.*")
If Len(filepath)=0 Then
Return
End If
///////////////OLE方式
If ole_1.InsertFile(filepath) <>0 Then
Return
End If
Blb_tmp=ole_1.ObjectData

/////PB帮助中的例子!改下就行了!直接读取文件



integer li_FileNum, loops, i

long flen, bytes_read, new_pos

blob b, tot_b

// Set a wait cursor

SetPointer(HourGlass!)

// Get the file length, and open the file

flen = FileLength(sle_filename.Text)

li_FileNum = FileOpen(sle_filename.Text, &

StreamMode!, Read!, LockRead!)

// Determine how many times to call FileRead

IF flen > 32765 THEN

IF Mod(flen, 32765) = 0 THEN

loops = flen/32765

ELSE

loops = (flen/32765) + 1

END IF

ELSE

loops = 1

END IF

// Read the file

new_pos = 1

FOR i = 1 to loops

bytes_read = FileRead(li_FileNum, b)

tot_b = tot_b + b

NEXT

FileClose(li_FileNum)

/////////////////////////
long row
row=dw_1.insertrow(0)
dw_1.setitem(row,"cou_id",jb)
dw_1.setitem(row,"sort1",filename)

bb=string(dw_1.object.id[row])

if dw_1.update()=1 then
UPDATEBLOB tms_cou_image SET book=:blb_tmp
WHERE cou_id=:jb and id=:bb ;
if sqlca.sqlcode = 0 then

commit using sqlca;
else
rollback using sqlca;
end if
else


rollback using sqlca;
end if

读书人网 >PB

热点推荐