不用dbgrid.colunm[0].picklist里面加字段
而是用table1里面的lookupdateset什么的,怎么设置??
我table1里面有字段'mc'和'xh'
table2 里面有字段'xh'
要table1里面的'xh'引用table2的'xh'
table1的xh字段是这样设置的FieldKind = fkLookup
FieldName = 'xh'
LookupDataSet = Table2
LookupKeyFields = 'xh'
LookupResultField = 'xh'
KeyFields = 'xh'
lookup=true可是这样不行,下拉框点击后出不来,怎么回事??
而是用table1里面的lookupdateset什么的,怎么设置??
我table1里面有字段'mc'和'xh'
table2 里面有字段'xh'
要table1里面的'xh'引用table2的'xh'
table1的xh字段是这样设置的FieldKind = fkLookup
FieldName = 'xh'
LookupDataSet = Table2
LookupKeyFields = 'xh'
LookupResultField = 'xh'
KeyFields = 'xh'
lookup=true可是这样不行,下拉框点击后出不来,怎么回事??
解决方案 »
- 为什么Filter过滤器不能被打开?
- 各位求救,delphi中excel另存为总是报错,为什么啊?
- 菜鸟问题!!!!!!我的DELPHI7中没有DBchart和chart,不知道如何才能找回。
- 用QReport控件制作报表,在报表预览时,能不能对其某些字段值进行修改
- [请教]在DELPHI中怎样控制网页中下拉列表的选择...
- 请大家帮忙!怎样用delphi7监控带有密码的access数据库?
- 请教:web server application 调试问题
- 二维码运行出错呀
- 使SQL的一种不可见字段sysname可见的方法,真的知道等于是白得分。
- UDP指令是啥
- 没有可用分提问的网友请给我发短消息
- 请教各位大哥QUICKREPORT的预览中总页数为什么会不停的增长?
---- 1、 在Delphi 4.0中新建一个项目。
---- 2、 分别拖动的Data Access组件板上DataSource、Table,Data Controls组件板上DBGrid,DBComboBox四个组件到Form1上。
---- 3、 设置各个组件的属性如下: rcf1对象 属性 设定植
Form1 Caption '在DBGrid中插入SpinEdit组件示例'
DataSource1 DataSet Table1
Table1 DatabaseName DBDEMOS
TableName 'teacher.DBF'
Active True
DBGrid1 DataSource DataSource1
DBComboBox1 DataField SEX
DataSource DataSource1
Visible False
Strings Items. '男'| '女' ---- 注意:我在这里用了Teacher.dbf,那是反映教职工的性别,只能是“男”或者是“女”。 ---- 4、 DrawDataCell事件是绘制单元格,当获得焦点网格所对应的字段与组合框所对应的字段一致时,移动组合框到获得焦点的网格上,并且
使组合框可视,从而达到在DBGrid指定列上显示DBComboBox的功能。设置DBGrid1的OnDrawDataCell事件如下:
procedure TForm1.DBGrid1DrawDataCell(Sender: TObject; const Rect: TRect; Field: TField; State: TGridDrawState);
begin
if (gdFocused in State) then
begin
if (Field.FieldName = DBComboBox1.DataField ) then
begin
DBComboBox1.Left := Rect.Left + DBGrid1.Left;
DBComboBox1.Top := Rect.Top + DBGrid1.top;
DBComboBox1.Width := Rect.Right - Rect.Left;
DBComboBox1.Height := Rect.Bottom - Rect.Top;
DBComboBox1.Visible := True;
end;
end;
end;---- 5、 DBGrid指定单元格未获得焦点时不显示DBComboBox,设置DBGrid1的OnColExit事件如下:
procedure TForm1.DBGrid1ColExit(Sender: TObject);
begin
If DBGrid1.SelectedField.FieldName = DBComboBox1.DataField then
begin
DBComboBox1.Visible := false;
end;
end;---- 6、 当DBGrid指定列获得焦点时DrawDataCell事件只是绘制单元格,并显示DBComboBox,但是DBComboBox并没有获得焦点,数据的输入还是在单元格上进行。在DBGrid1的KeyPress事件中调用SendMessage这个 Windows API函数将数据输入传输到DBComboBox上,从而达到在DBComboBox上进行数据输入。因此还要设置KeyPress事件如下:
procedure TForm1.DBGrid1KeyPress(Sender: TObject; var Key: Char);
begin
if (key < > chr(9)) then
begin
if (DBGrid1.SelectedField.FieldName =DBComboBox1.DataField) then
begin
DBComboBox1.SetFocus;
SendMessage(DBComboBox1.Handle, WM_Char, word(Key), 0);
end;
end;
end;---- 程序在中文Windows 98,Delphi 4.015 下调试通过。希望本文能使你可以更加方便快捷的开发数据库应用程序。
不想那么复杂
:)
帮帮忙
分不够再加,我分多的是:)
在 Table 中右键的 Fields Editor 中 添加一个新字段,设置一下,类型选择为 LookUp,在进行设置,看看就知道了。
具体的参数我写在上面了,帮帮我,我马上给分!
1
1
1
)
其实查找字段是用来关联主从表的关联字段的,你首先要理解查找字段得用法以及主从表的关系才能正确使用
应该怎么设置??
然后使用
procedure TForm1.Button1Click(Sender: TObject);
var
i:integer;
FldValue:String;
begin//在作这个之前你的DBGrid所连的数据集一定要打开
for i:=0 to DBGrid1.Columns.Count-1 do
//这个循环用来找你要的加PickList的DBGrid的Column
if DBGrid1.Columns[i].Field
=DBGrid1.DataSource.DataSet.FieldByName('xh') then
begin
DBGrid1.Columns[i].PickList.Clear;
Table2.First;
while not Table2.Eof do
begin
FldValue:=Table2.FieldByName('xh').AsString;
if DBGrid1.Columns[i].PickList.IndexOf(FldValue)>-1 then
DBGrid1.Columns[i].PickList.Add(FldValue);
//把Table2中的xh字段值加到PickList中,并保证每个不同
Table2.Next;
end;
break;
end;
end;
if DBGrid1.Columns[i].PickList.IndexOf(FldValue)>-1 then
DBGrid1.Columns[i].PickList.Add(FldValue);
//把Table2中的xh字段值加到PickList中,并保证每个不同
改为:
if DBGrid1.Columns[i].PickList.IndexOf(FldValue)<0 then
DBGrid1.Columns[i].PickList.Add(FldValue);
//把Table2中的xh字段值加到PickList中,并保证每个不同
TForm1.FormCreateFormCreate(Sender: TObject);
begin
with Table1 do
if Active then
Refresh
esle
Open;
with Table2 do
if Active then
Refresh
else
Open;
end;
下拉框点击后出不来是因为你没有打开Table2,你也可以在设计时将Table1,Table2的Active属性设为True,这样保证没错,试试看
你一选择下拉列表时,那个关联的数据源的数据也跟着滚动, 好烦!!如果用上面的动态加Packlist设置可是可以,但要做写添加packlist代码而且,
要写ongettext,onsettext事件代码..太慢!delphi做数据库,怎一个烦字了得!