[英]The Image in the picture box does not change
请在这里我需要帮助。 我正在使用来自gridview的数据来填充文本框和pictureBox。 当我单击一行时,文本框会填满。 但是图片框仅显示一张图像。 不管我选择哪一行显示相同的图像。 请我是C#的新手,我需要帮助。 到目前为止,这是我所做的事情private void viewMemberGrid_CellClick(object sender,DataGridViewCellEventArgs e){
DataGridViewRow dr = viewMemberGrid.SelectedRows[0];
GmemIDBox.Text = dr.Cells[0].Value.ToString();
GsurnameBox.Text = dr.Cells[1].Value.ToString();
GfirstnameBox.Text = dr.Cells[2].Value.ToString();
GphoneBox.Text = dr.Cells[3].Value.ToString();
memDeptBox.Text = dr.Cells[7].Value.ToString();
memPortBox.Text = dr.Cells[8].Value.ToString();
GaddBox.Text = dr.Cells[5].Value.ToString();
GdobBox.Text = dr.Cells[6].Value.ToString();
string select = "Select NEWMEMBER.MemberID, Surname, Firstname, PhoneNumber, MemberPic, HomeAddress,DOB,DeptID,PortfolioDesc from NEWMEMBER inner join Pictures on NEWMEMBER.MemberID = Pictures.MemberID join PortfolioDescription on PortfolioDescription.PortfolioId = NEWMEMBER.PortfolioID";
SqlConnection c = new SqlConnection("Data Source=.;Initial Catalog=Cmanager;Integrated Security=True");
SqlCommand cmd = new SqlCommand(select, c);
try
{
c.Open();
SqlDataReader dro = cmd.ExecuteReader();
if (dro.Read())
{
byte[] picarr = (byte[])dro["MemberPic"];
MemoryStream ms = new MemoryStream(picarr);
ms.Seek(0, SeekOrigin.Begin);
memPicBox.Image = Image.FromStream(ms);
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
c.Close();
}
对您的选择语句进行一些更改
;
我不知道您在数据库中的MemberID列是数字还是Varchar
。
;
如果是数字
string select = "Select NEWMEMBER.MemberID, Surname, Firstname, PhoneNumber, MemberPic, HomeAddress,DOB,DeptID,PortfolioDesc from NEWMEMBER inner join Pictures on NEWMEMBER.MemberID = Pictures.MemberID join PortfolioDescription on PortfolioDescription.PortfolioId = NEWMEMBER.PortfolioID Where NEWMEMBER.MemberID = " + dr.Cells[0].Value.ToString();
或者如果是Varchar
string select = "Select NEWMEMBER.MemberID, Surname, Firstname, PhoneNumber, MemberPic, HomeAddress,DOB,DeptID,PortfolioDesc from NEWMEMBER inner join Pictures on NEWMEMBER.MemberID = Pictures.MemberID join PortfolioDescription on PortfolioDescription.PortfolioId = NEWMEMBER.PortfolioID Where NEWMEMBER.MemberID = '" + dr.Cells[0].Value.ToString() + "'";
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.