多层结构中嵌套数据的提交问题(真的没人愿意指教吗?分不够可以加) (100分)

  • 主题发起人 主题发起人 ysiwei
  • 开始时间 开始时间
Y

ysiwei

Unregistered / Unconfirmed
GUEST, unregistred user!
在三层应用中使用了DCOM的嵌套数据结构,发现所有的Nvarchar类型字段,在数据提交时
字段被用空格进行补位,如:字段长度为10时,不管存入数据为几位,读备用空格补位成长度
为10。
 
各位高手,如果分低可以再加,请多多关注
 
现在已经解决,仅仅将DataSetProvider中ResolveToDataSet设为真即可
 
你已经解决了,我就插句嘴吧,如果你用的SQL server做后端,字段类型
设成char而不是varchar也会出现这种情况。
 
学知识:)
 
[?]运行发现,这种解决办法由于通过了DataSet进行数据存储,效率有所下降,跟踪ResolveToDataset
为False是的SQL语句发现此缺陷是Delphi自身所带的,跟踪Delphi自动生成的SQL结果:
exec sp_executesql N'insert into table1
(exp1, exp2, exp3, exp4, exp5, exp6, exp7, exp8, exp9, exp10, exp11, exp12)
values
(@P1, @P2, @P3, @P4, @P5, @P6, @P7, @P8, @P9, @P10, @P11, @P12)',
N'@P1 nchar(20),@P2 nchar(20),@P3 nchar(20),@P4 nchar(50),@P5 datetime,@P6 datetime,
@P7 nchar(20),@P8 datetime,@P9 nchar(20),@P10 nchar(50),@P11 nchar(20),@P12 nchar(20)',
N'3 ',
N'3 ',
N'3 ',
N'3 ',
'12 30 1899 3:00AM',
'12 30 1899 3:00AM',
N'3 ',
'12 14 2002 11:08AM',
N'3 ',
N'3 ',
N'3 ',
N'3 '
请问各位高手是否可以避免此缺陷
 
嵌套数据?什么意思啊
 
可变长字符串就是这样传输的(我指SQL2K,其它的不知道),和三层、二层
也没什么关系,不信,你可以在SQL的企业管理器里面自己看。
如果你对这个敏感,用定长字符串算了。:)
以个人习惯来说,我更倾向于ADO+resolvetodataset=True。
 
用provider的BeforeUpdateRecord分离数据吧
 

Similar threads

S
回复
0
查看
3K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
2K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
1K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
900
SUNSTONE的Delphi笔记
S
D
回复
0
查看
1K
DelphiTeacher的专栏
D
后退
顶部