谢谢各位了 C++Build 4.0 总是说我 invaild blob length 在SQL SERVER 7.0

wwxxkk250 2000-08-04 12:07:00
//字段说明为:pict_name char(10), m_pict image
//数据库为SQL SERVER 7.0 编程语言为c++build4.0
//问题是总是说我 invaild blob length
//谢谢各位了
//在DataBase中我以设为 blob szie = 90000
void __fastcall TForm1::FormCreate(TObject *Sender)
{

TB1->DatabaseName="bbb";
AnsiString S,S1;
for(int i=0;i<32767;i++) S1=S1+"a";
int aa=S1.Length();
for(int i=0;i<2;i++)
S=S+S1;
aa= S.Length();
TB1->Open();
TB1->Edit();
TB1->Insert();
TB1->FieldByName("pict_name")->AsString="1";
TB1->FieldByName("m_pict")->AsVariant=S.c_str();
TB1->Post();
if (TB1->State == dsEdit)
{
TBlobStream *pStream;
pStream =new TBlobStream((TBlobField*)TB1->FieldByName
("m_pict"),bmReadWrite);

pStream->Write(S.c_str,S.Length());
TB1->Post();
//问题是S不能超过32767长
delete pStream;
}
TB1->Close();
}
...全文
87 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
Wingsun 2000-08-07
  • 打赏
  • 举报
回复
不对,Blob cache不能随便设置,Blob Cache的数值表示Cache多少条记录。是应该修改Blob Size的大小,在BDE的设置中修改。
ninestar 2000-08-07
  • 打赏
  • 举报
回复
你的Blob size必须设置成2的整数倍,如32,64,1024等等,另外blob cache最好设置成blob size的两倍,这样就不会出现上述错误了。

69,336

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧