DBGrid1 通过 ADOConnection1 ADOQuery1 DataSource1 连接的数据库//SQL查询memo2.Text:= select CX.lsh AS 流水号,CX.bh AS 编号,JF.xm AS 姓名,ITEM.name AS ''※科室※'',TT.name AS ''※医生※'',from gk_ys_mzcf AS CX INNER JOIN zd_unit_code AS ITEM ON CX.sfbm=ITEM.code INNER JOIN a_employee_mi AS TT ON CX.kdys=TT.code INNER JOIN gk_mz_settle AS JF ON CX.jslsh=JF.jslsh INNER JOIN a_employee_mi AS MM ON JF.jsr=MM.codewhere .......... DBGrid1.DataSource.DataSet.Close; DBGrid1.DataSource := DataSource1; //切换数据链接 ADOQuery3.SQL.Clear; ADOQuery3.Close; ADOQuery3.SQL.Text := memo2.Text; ADOQuery3.Open;//下拉框1ADOQuery1.Close; ADOQuery1.SQL.Text := 'select name,seq from zd_unit_code where groupno = 1 order by name asc'; ADOQuery1.Open; iCount1 := ADOQuery1.RecordCount; for ii := 1 to iCount1 do begin DBGrid1.Columns[3].PickList.Add(StringReplace(ADOQuery1.FieldByName('name').AsString, ' ', '', [rfReplaceAll])); ADOQuery1.Next;end;//DBGrid1CellClick事件代码ADOQuery1.Close; ADOQuery1.SQL.Text := 'update gk_ys_mzcf SET sfbm='''+m+''',kdys='''+n+''' where cfbh = '''+o+''''; ADOQuery1.ExecSQL;显示结果如右图,想实现左图中的效果现在存在两个问题:第一DBGrid需要点击该列才会出现下拉箭头,不会像图一那样一直显示。第二我在DBGrid1CellClick添加更新数据库事件来更新数据,点当前行工作正常,但是我修改某数据后如果点非当前行就会报错“无法为更新定位行。一些值可能已在最后一次读取后已更改。”按照网上提供的方法把ADOQuery3,ADOQuery1控件的CursorLocation属性为clUseServer就不会报错了,可是我选择的数据被更新到zd_unit_code表里了,我想要更新的是DBGrid1CellClick事件里的gk_ys_mzcf 表啊。如何让这里修改后选择其它行不报错,也不更新到gk_ys_mzcf 表。---------------------------------数据描述:表里大概内容gk_ys_mzcf表cfbh gkbh jzkh xm sflb sfbm kdys201707310410 111726 20184443 NULL 1 71 470201707310411 111726 20184443 NULL 1 71 470描述:cfbh 唯一识别号,sfbm 和表zd_unit_code的seq对应,kdys和表a_employee_mi seq 对应。a_employee_mi表seq name470 张三471 李四zd_unit_code表seq name71 妇科72 男科实现目标:我查看数据是中文显示的如上面右图sfbm 的71和kdys的470显示的是妇科 张三下拉也是中文的有张三和李四,科室有妇科男科,选择后 科室更改为男科,医生更改为李四后点其它任何地方就更新数据,注意更新的是我选择文字对应的seq值,也就是变成72 471而且只改变我修改的那条,其它cfbh的不变。