c#中datagridview怎么设置将combobox放进去

以前学习delphi是这样的,通过combobox连接数据库,然后通过控件直接就能把combobox的内容显示在某行,貌似c#不行,求指导,需要用代码吗?怎么写网上貌似很... 以前学习delphi是这样的,通过combobox连接数据库,然后通过控件直接就能把combobox的内容显示在某行,貌似c#不行,求指导,需要用代码吗?怎么写 网上貌似很多 看的不清楚 展开
 我来答
xiangjuan314
2016-01-18 · TA获得超过3.3万个赞
知道大有可为答主
回答量:2.9万
采纳率:0%
帮助的人:2760万
展开全部
DataGridViewComboBoxColumn pCombo;
private void Teaching_Add_Load(object sender, EventArgs e)
{
MyDBase DB = new MyDBase(DBUser.sserver,DBUser.DBName, DBUser.suser, DBUser.spasswd);
DataSet DS= DB.GetRecordset("select * from view_teach_tmp");
dataGridView1.DataSource = DS.Tables[0];
pCombo = new DataGridViewComboBoxColumn();
SqlDataReader RD = DB.DBDataReader("select * from expert");
while (RD.Read())
{
string st = RD[0].ToString().Trim() + "." + RD[1].ToString().Trim();
pCombo.Items.Add(st);
}
RD.Close();
dataGridView1.Columns.Add(pCombo);
dataGridView1.Columns[7].HeaderText = "请选择专家";
DB.DBClose();
}
说明:
1.dataGridView中添加comboBox控件利用初始化现成的类DataGridViewComboBoxColumn,本例先把从view_teach_tmp中读出的数据加到dataGridView1中,然后把初始化的comboBox控件pCombo加到最后一列,并给标题HeaderText命名。
2.pCombo控件中显示的是expert表中的“编码.专家姓名”,若要获取编码,可用下面的函数GetENo。
string GetENo(string st)
{
int n, i;
string s = "";
n = st.Length;
for (i = 0; i < n; i++)
{
if (st.Substring(i, 1) == ".") return s;
s = s + st.Substring(i, 1);
}
return "-1";
}
3.调用函数GetENo:
string ENo;

for (int i = 0; i < n; i++)
{
if (dataGridView1.Rows[i].Cells[7].Value == null)
{
MessageBox.Show("请选择专家", "错误提示", MessageBoxButtons.OK, MessageBoxIcon.Error);
return;
}
ENo = dataGridView1.Rows[i].Cells[7].Value.ToString();
ENo = GetENo(ENo);
}
特别说明:
要判断pCombo控件是否全都选值,要使用if (dataGridView1.Rows[i].Cells[7].Value == null),起初使用if (dataGridView1.Rows[i].Cells[7].Value.Tostring().Trim().Length==0)语句,直接报错
微测检测5.10
2023-05-10 广告
您好!建议咨 深圳市微测检测有限公司,已建立起十余个专业实验室,企业通过微测检测就可以获得一站式的测试与认 证解决方案;(EMC、RF、MFi、BQB、QI、USB、安全、锂电池、快充、汽车电子EMC、汽车手机互 联、语音通话质量),认证遇... 点击进入详情页
本回答由微测检测5.10提供
liyan922107
2014-07-16 · 超过72用户采纳过TA的回答
知道小有建树答主
回答量:301
采纳率:0%
帮助的人:166万
展开全部
在 FormLoad 事件中 DataGridView1.Controls.Add(ComboBox1);

在 DataGridView 的CurrentCellChanged事件中
private void dg1_CurrentCellChanged(object sender, EventArgs e)
{ DataGridViewCell CurrnetCell = dg1.CurrentCell;

if(CurrnetCell!=null && CurrnetCell.OwningColumn.Name=="第三列")
{
....sql返回dataset
ComboBox1.Visible = true;
ComboBox1.DataSource = tableNameCombox.DefaultView;
ComboBox1.DisplayMember = "ColumnName";
ComboBox1.ValueMember = "Num";

System.Drawing.Rectangle TmpRect = dg1.GetCellDisplayRectangle(CurrnetCell.ColumnIndex, CurrnetCell.RowIndex, true);
ComboBox1.Size = TmpRect.Size;
ComboBox1.Top = TmpRect.Top;
ComboBox1.Left = TmpRect.Left;
}
追问
抄也要看题目抄啊 ~~我要的都没这么复杂
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式