TDBGridEh表格 lookupParams 使用

本文介绍了如何通过设置TClientDataset的CommandText和TGrid的Columns属性,实现在表格中显示DepartmentID对应的部门名称,同时在下拉框中展示部门的Code和Department两个字段,避免了不必要的数据库关联操作。详细配置包括lookupParams、lookupDataset等关键设置,实现了高效的数据展示效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

客户的:cdsCustomer :TclientDataSet 的CommandText 为下的,中包含了DepartmentID 部门ID,这里不用关联
Department 表的DepartmentID字段
CommandText :='select top 10 CustomerID,Code,Customer,DepartmentID from Customer ';

客户显示的表格如下设置
Grideh1.columns[2].FieldName :='DepartmentID';  //部门名称
Grideh1.columns[2].Title.Caption :='所属部门';

Grideh1.columns[2].DropDownBox.autoFitColWidths :=False;
Grideh1.columns[2].DropDownBox.columns[0].FieldName :='Code';//部门编码
Grideh1.columns[2].DropDownBox.columns[0]。Title.Caption:='部门编码';

Grideh1.columns[2].DropDownBox.columns[1].FieldName :='Department';
Grideh1.columns[2].DropDownBox.columns[1]。Title.Caption:='部门名称';
//两列设置好列宽,把看自动适应列宽 去掉,设置一个固定的列宽 80 ,100
--以下重点设置
Grideh1.columns[2].lookupParams.KeyFieldNames :='DepartmentID';
Grideh1.columns[2].lookupDataset :=cdsDepartment;//TClientDataset 的 部门数据集
Grideh1.columns[2].lookupDisplayFieldName :='Department';
Grideh1.columns[2].lookupKeyFieldNames  :='DepartmentID';//这个视情况而定,这个应该是查询条件吧暂没测试
cdsDepartment.CommandText  :='select DepartmentID,Code,Department from Department ';

这样设置open 数据数据集即可显示 部门名称 ,这样做的意义在于,下拉可以显示多个字段,效果如果下图

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值