各位大虾:datagridview中的combobox列

birdfpl04 2009-03-21 09:03:22
各位大虾:datagridview中的几列改为combobox了,数据也绑定了,总是提示默认值错误不知道怎么改正,请各位帮忙.同时我不想取出数据库种的数据,只想直接插入怎么改!谢谢
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;

namespace lksystem
{
public partial class Frmshadd : Form
{
public SqlDataAdapter da;
public DataSet ds;
public SqlConnection mycon;
public Frmshadd()
{
InitializeComponent();
}
protected override bool ProcessCmdKey(ref Message msg, Keys keyData)//重写键盘回车代码
{
if ((!(ActiveControl is Button)) && (keyData == Keys.Up || keyData == Keys.Down || keyData == Keys.Enter))
{
if (keyData == Keys.Enter)
{
System.Windows.Forms.SendKeys.Send("{TAB}");
return true;
}
if (keyData == Keys.Down)
System.Windows.Forms.SendKeys.Send("{TAB}");
else
SendKeys.Send("+{Tab}");
return true;
}
else
return base.ProcessCmdKey(ref msg, keyData);
}


private void Frmshadd_Load(object sender, EventArgs e)
{
mycon = new SqlConnection("server=127.0.0.1;database=lkdata;user id=sa;pwd=");
da = new SqlDataAdapter("select sdhdm,bmdm,xybh,shmc,jjrq,sprq,zcfr,lxdh,zcdz,gsbh,swbh,shly,hydm,shzt from tb_sh", mycon);

ds = new DataSet();
SqlDataAdapter da1 = new SqlDataAdapter("select sdhdm,sdhmc from tb_sdh", mycon);
SqlDataAdapter da2 = new SqlDataAdapter("select bmdm,bmmc from tb_bm", mycon);
SqlDataAdapter da3 = new SqlDataAdapter("select hydm,hymc from tb_hy", mycon);
SqlDataAdapter da4 = new SqlDataAdapter("select zydm zymc from tb_zy", mycon);
SqlCommandBuilder cb = new SqlCommandBuilder(da);
da.Fill(ds, "tb_sh");
da1.Fill(ds, "tb_sdh");
da2.Fill(ds, "tb_bm");
da3.Fill(ds, "tb_hy");
da4.Fill(ds, "tb_zy");
dgvaddsh.AutoGenerateColumns = false;
dgvaddsh.DataSource = ds.Tables[0];

DataGridViewComboBoxColumn sdhdm=new DataGridViewComboBoxColumn ();
DataGridViewComboBoxColumn bmdm=new DataGridViewComboBoxColumn ();
DataGridViewComboBoxColumn shly=new DataGridViewComboBoxColumn ();
DataGridViewComboBoxColumn hydm=new DataGridViewComboBoxColumn() ;
dgvaddsh.Columns[0].DataPropertyName = "sdhdm";
dgvaddsh.Columns[1].DataPropertyName = "bmdm";
dgvaddsh.Columns[2].DataPropertyName = "xybh";
dgvaddsh.Columns[3].DataPropertyName = "shmc";
dgvaddsh.Columns[4].DataPropertyName = "jjrq";
dgvaddsh.Columns[5].DataPropertyName = "sprq";
dgvaddsh.Columns[6].DataPropertyName = "zcfr";
dgvaddsh.Columns[7].DataPropertyName = "lxdh";
dgvaddsh.Columns[8].DataPropertyName = "zcdz";
dgvaddsh.Columns[9].DataPropertyName = "gsbh";
dgvaddsh.Columns[10].DataPropertyName = "swbh";
dgvaddsh.Columns[11].DataPropertyName = "shly";
dgvaddsh.Columns[12].DataPropertyName = "hydm";
dgvaddsh.Columns[13].DataPropertyName = "shzt";
sdhdm.DataSource = ds.Tables[1];
sdhdm.ValueMember = "sdhdm";
sdhdm.DisplayMember = "sdhdm";

bmdm.DataSource = ds.Tables[2];
bmdm.ValueMember = "bmdm";
bmdm.DisplayMember = "bmdm";

shly.DataSource = ds.Tables[4];
shly.ValueMember = "zydm";
shly.DisplayMember = "zydm";
hydm.DataSource = ds.Tables[3];
hydm.ValueMember = "hydm";
hydm.DisplayMember = "hydm";
}

private void tsbsave_Click(object sender, EventArgs e)
{
try
{
da.Update(ds.Tables[0]);
MessageBox.Show("新增成功");
}
catch(Exception err)
{
mycon .Close();
MessageBox .Show( err.ToString ());
}

}


}
}
...全文
101 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
mathieuxiao 2009-03-27
  • 打赏
  • 举报
回复

shly.DataSource = dv;
shly.ValueMember = "zydm";
shly.DisplayMember = "zydm";
mathieuxiao 2009-03-27
  • 打赏
  • 举报
回复
都可以,但是直接在select语句后面也行

DataView dv = ds.Tables[0].DefaultView;
dv.Filter = "sex = '男'";//这样就可以取出性别为男的所有数据了
chinaconstraint 2009-03-27
  • 打赏
  • 举报
回复
不是可以用三层DataView过滤实现么
mathieuxiao 2009-03-27
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 birdfpl04 的回复:]
我的整个意图是要做新增记录操作的. 确实是提示默认错误,谢谢mathieuxiao 的提示,我检查以下是不是数据不一致造成的.另外一个问题是 da = new SqlDataAdapter("select sdhdm,bmdm,xybh,shmc,jjrq,sprq,zcfr,lxdh,zcdz,gsbh,swbh,shly,hydm,shzt from tb_sh", mycon);
会将我库中所有记录都取出来,这个是我不想的,不知道怎么改才能实现.请各位帮助.谢谢!
[/Quote]

你直接在select语句后加个where条件就可以了
birdfpl04 2009-03-23
  • 打赏
  • 举报
回复
同时感谢三楼的,也帮我搞定了一个问题.
birdfpl04 2009-03-23
  • 打赏
  • 举报
回复
我的整个意图是要做新增记录操作的. 确实是提示默认错误,谢谢mathieuxiao 的提示,我检查以下是不是数据不一致造成的.另外一个问题是 da = new SqlDataAdapter("select sdhdm,bmdm,xybh,shmc,jjrq,sprq,zcfr,lxdh,zcdz,gsbh,swbh,shly,hydm,shzt from tb_sh", mycon);
会将我库中所有记录都取出来,这个是我不想的,不知道怎么改才能实现.请各位帮助.谢谢!
birdfpl04 2009-03-23
  • 打赏
  • 举报
回复
谢谢各位
灵魂宝石 2009-03-22
  • 打赏
  • 举报
回复
kbtjh 2009-03-22
  • 打赏
  • 举报
回复
顶,,学习一下!!!
wuyq11 2009-03-22
  • 打赏
  • 举报
回复
http://www.cnblogs.com/luqingfei/archive/2007/03/28/691372.html
mathieuxiao 2009-03-22
  • 打赏
  • 举报
回复
如果提示默认值错误,很可能是因为你的数据库表中的值和你下拉框中Items里面包含的值不是完全一样。换句话话说,你的下拉框中有两个选项“1”和“2”,但是你的表中这一列的数据中有个值为“3”,这样就可能导致你的所出现的错误。

如果下拉框列的数据不想从数据库中去也是可以的,如下:

Class Department //代表部门
{
int _depId;
string _depName;

public int DepId{get{return this._depId;} set{this._depId = value;}}
public string DepName{get{return this._depName;} set{this._depName= value;}}

public Department(int id, string name)
{
this._depId = id; this._depName = name;
}
}

public partial class Frmshadd : Form
{
public form_load(object sender, EventArgs e)
{
List<Department> depList = new List<Department>();
depList.Add(new Department(1, "财务部"));
depList.Add(new Department(2, "业务部"));

DataGridViewComboBoxColumn cboCol = new DataGridViewComboBoxColumn();

cboCol.ValueMember = "DepId";
cboCol.DisplayMember = "DepName";
cboCol.DataSource = depList;

cboCol.DataPropertyName = "Department";//这个值和你数据库中的列名保持一致

this.dataGridView1.Columns.Add(cboCol);
}
}
优途科技 2009-03-21
  • 打赏
  • 举报
回复
不太明白你的意思。顶你一下吧。
vb.net操作DataGridView控件的用法的集合,包括: 1. DataGridView当前的单元格属性取得、变更 2. DataGridView编辑属性 3. DataGridView最下面一新追加行非表示 4. DataGridView判断当前选行是否为新追加的行 5. DataGridView删除行可否设定 6. DataGridView不表示和删除 DataGridView控件用法合集(二) 7. DataGridView宽度高度设置为不能编辑 8. DataGridView行高幅自动调整 9. DataGridView指定行冻结 10. DataGridView顺序变更可否设定 11. DataGridView行复数选择 12. DataGridView选择的行、、单元格取得 DataGridView控件用法合集(三) 13. DataGridView指定单元格是否表示 14. DataGridView表头部单元格取得 15. DataGridView表头部单元格文字设定 16. DataGridView选择的部分拷贝至剪贴板 17.DataGridView粘贴 18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息) DataGridView控件用法合集(四) 19. DataGridView的ContextMenuStrip属性 20. DataGridView指定滚动框位置 21. DataGridView手动追加 22. DataGridView全体分界线样式设置 23. DataGridView根据单元格属性更改显示内容 24. DataGridView新追加行的行高样式设置る 25. DataGridView新追加行单元格默认值设置 DataGridView输入错误数据的处理(五) 26. DataGridView单元格数据错误标签表示 27. DataGridView单元格内输入值正确性判断 28. DataGridView单元格输入错误值事件的捕获 DataGridView控件用法合集(六) 29. DataGridView行排序(点击表头自动排序的设置) 30. DataGridView自动行排序(新追加值也会自动排序) 31. DataGridView自动行排序禁止情况下的排序 32. DataGridView指定指定排序 DataGridView控件用法合集(七) 33. DataGridView单元格样式设置 34. DataGridView文字表示位置的设定 35. DataGridView单元格内文字换行 36. DataGridView单元格DBNull值表示的设定 37. DataGridView单元格样式格式化 38. DataGridView指定单元格颜色设定 39. DataGridView单元格文字字体设置 40. DataGridView根据单元格值设定单元格样式 DataGridView控件用法合集(八) 41. DataGridView设置单元格背景颜色 42. DataGridView行样式描画 43. DataGridView显示行号 44. DataGridView焦点所在单元格焦点框不显示的设定 DataGridView控件用法合集(九) 45. DataGridView显示选择框CheckBox 46. DataGridView显示下拉框ComboBox 47. DataGridView单击打开下拉框 48. DataGridView显示按钮 49. DataGridView显示链接 50. DataGridView显示图像 DataGridView控件用法合集(十) 51. DataGridView编辑单元格控件取得 52. DataGridView输入自动完成 53. DataGridView单元格编辑时键盘KEY事件取得 54. DataGridView下拉框(ComboBox)单元格编辑时事件取得 55. DataGridView下拉框(ComboBox)单元格允许文字输入设定 DataGridView控件用法合集(十一) 56. DataGridView根据值不同在另一显示相应图片 57. DataGridView显示进度条(ProgressBar) 58. DataGridView添加MaskedTextBox DataGridView控件用法合集(十二) 59. DataGridViewEnter键按下焦点移至旁边的单元格 60. DataGridView行集合化(Group)

111,126

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Creator Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧