c# - 从 mysql 数据库将图像加载到 picturebox 时出错。空引用异常

标签 c# mysql picturebox

我正在尝试从数据库中获取图像并显示到图片框中。我的代码在下面

private void getImage()
{
    using (MySqlConnection conn = new MySqlConnection(connectionManager.connectionString))
    {
        try
        {
            conn.Open();

            string query = "SELECT 'Image' FROM student_img WHERE ID =  @ID";

            MySqlCommand cmd = new MySqlCommand(query, conn);

            int id = 10;
            cmd.Parameters.AddWithValue("@ID", id);

            var da = new MySqlDataAdapter(cmd);
            var ds = new DataSet();
            da.Fill(ds, "Image");
            int count = ds.Tables["Images"].Rows.Count;

            if (count > 0)
            {
                var data = (Byte[])(ds.Tables["Images"].Rows[count - 1]["Image"]);
                var stream = new MemoryStream(data);
                picLogo.Image = Image.FromStream(stream);
            }
        }
        catch (Exception ex)
        {
            MessageBox.Show("Connection Error!\n" + ex.Message, "Error Message",
                    MessageBoxButtons.OK, MessageBoxIcon.Error);
        }
    }

}

但我收到 NullReferenceException 错误。我还有另一种方法,也许我可以以某种方式使用它,但我不确定如何从数据库中获取数据,因为我是 C# 的新手

public Image byteArrayToImage(byte[] byteArrayIn)
{
    MemoryStream ms = new MemoryStream(byteArrayIn);
    Image returnImage = Image.FromStream(ms);
    return returnImage;
}

最佳答案

设法解决问题,不得不改变

Images

Image

private void getImage()
        {
            using (MySqlConnection conn = new MySqlConnection(connectionManager.connectionString))
            {
                try
                {
                    conn.Open();

                    string query = "SELECT Image FROM student_img WHERE ID =  @ID";

                    MySqlCommand cmd = new MySqlCommand(query, conn);

                    int id = 10;
                    cmd.Parameters.AddWithValue("@ID", id);

                    var da = new MySqlDataAdapter(cmd);
                    var ds = new DataSet();
                    da.Fill(ds, "Image");
                    int count = ds.Tables["Image"].Rows.Count;

                    if (count > 0)
                    {
                        var data = (Byte[])(ds.Tables["Image"].Rows[count - 1]["Image"]);
                        var stream = new MemoryStream(data);
                        picLogo.Image = Image.FromStream(stream);
                    }

                }
                catch (Exception ex)
                {
                    MessageBox.Show("Connection Error!\n" + ex.Message, "Error Message",
                            MessageBoxButtons.OK, MessageBoxIcon.Error);
                }
            }

        }

关于c# - 从 mysql 数据库将图像加载到 picturebox 时出错。空引用异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35420283/

相关文章:

c# - 日期格式在带有 Entity Framework 的 MVC 中不起作用?

c# - Unity Sprite 图集有奇怪的大小

c# - 放大图像而不会弄脏像素

vb.net - 设置图片框中图像的大小?

c# - DotNetZip - 如何在不创建单独文件的情况下保存回原始流

c# - Microsoft Exchange 网络服务网址

mysql - Moodle 1.9 REPLACE 破坏 utf8_unicode_ci 字符串

php - 警告 : mysqli_fetch_array() error displaying SQL code

mysql通过单个查询获取结果父ID和类别ID?

c# - 如何在编辑后将图片框控件另存为 jpeg 文件