通常,我们在开发软件或者网站是否,通常有时候需要添加图片,我们怎么做呢,直接贴例子。

前提是添加openFileDialog控件哈

#region 定义公共的类对象及变量
        SqlConnection sqlcon;       //声明数据库连接对象
        SqlDataAdapter sqlda;        //声明数据桥接器对象
        DataSet myds;                     //声明数据集对象
        //定义数据库连接字符串
        //string strCon = @"Data Source=lll;Database=db_CSharp;uid=sa;pwd=;";
        string strCon = "Data Source=ASUS-PC;Initial Catalog=BookManager;Integrated Security=True";
        #endregion

private void AddPhoto_Load(object sender, EventArgs e) //初始化
        {
            ShowInfo();//显示用户信息
        }

【1】选择图片按钮

private void button1_Click(object sender, EventArgs e)//选择图片
        {
            //定义可选择的头像类型
            openFileDialog1.Filter = "*.jpg,*jpeg,*.bmp,*.ico,*.png,*.tif,*.wmf|*.jpg;*jpeg;*.bmp;*.ico;*.png;*.tif;*.wmf";
            openFileDialog1.Title = "选择用户头像";
            //判断是否选择了头像
            if (openFileDialog1.ShowDialog() == DialogResult.OK)
            {
                //显示选择的用户头像
                pictureBox1.Image = Image.FromFile(openFileDialog1.FileName);
                textBox1.Text = "";
            }
        }

【2】保存图片按钮

private void button2_Click(object sender, EventArgs e)
        {
            if (textBox1.Text.Trim() == "")
            {
                MessageBox.Show("用户名不为空","信息提示");
            }
            if (openFileDialog1.FileName == "")
            {
                MessageBox.Show("用户头像不为空", "信息提示");
            }

sqlcon = new SqlConnection(strCon);//创建链接对象
            sqlcon.Open();//打开数据库
            string sqlstr = "select * from userphoto where name='"+textBox1.Text.Trim()+"'";
            SqlCommand Mycom = new SqlCommand(sqlstr,sqlcon);
            Mycom.ExecuteNonQuery();
            if (null != Mycom.ExecuteScalar())
            {
                MessageBox.Show("用户名 "+textBox1.Text.Trim() + " 已经存在,请重新注册用户名", "信息提示");
                textBox1.Text = "";
                textBox1.Focus();
            }
            //sqlcon.Close();//关闭数据库
            /***************************************************************/
           else if (openFileDialog1.FileName != "" && textBox1.Text != "")//如果用户名不为空,并且文件被选中
            {
                //添加用户信息
                if (AddInfo(textBox1.Text, openFileDialog1.FileName))
                {
                    MessageBox.Show("用户信息添加成功", "信息提示");
                }
               
            }
            //else
            //{ 
            //    MessageBox.Show("请您输入用户名", "信息提示"); 
            //}
            sqlcon.Close();//关闭数据库
            ShowInfo();
        }

【3】调用的函数:

#region 添加用户信息
        /// <summary>
        /// 添加用户信息
        /// </summary>
        /// <param name="strName">用户名称</param>
        /// <param name="strImage">选择的头像名称</param>
        /// <returns>执行成功,返回true</returns>
        private bool AddInfo(string strName, string strImage)
        {
            sqlcon = new SqlConnection(strCon);//创建数据库连接对象

FileStream FStream = new FileStream(//创建文件流对象
                strImage, FileMode.Open, FileAccess.Read);
            BinaryReader BReader = new BinaryReader(FStream);//创建二进制流对象
            byte[] byteImage = BReader.ReadBytes((int)FStream.Length);//得到字节数组

SqlCommand sqlcmd = new SqlCommand(//创建命令对象
                "insert into userphoto(name,photo) values(@name,@photo)", sqlcon);

sqlcmd.Parameters.Add("@name", //添加参数并赋值
                SqlDbType.VarChar, 50).Value = strName;
            sqlcmd.Parameters.Add("@photo",//添加参数并赋值
                SqlDbType.Image).Value = byteImage;

sqlcon.Open();//打开数据库连接
            sqlcmd.ExecuteNonQuery();//执行SQL语句
            sqlcon.Close();//关闭数据库连接
            return true;//方法返回布尔值
        }
        #endregion

*******************************************************************

#region 在DataGridView中显示用户名称
        /// <summary>
        /// 在DataGridView中显示用户名称
        /// </summary>
        private void ShowInfo()//显示到DataGridView表格
        {
            sqlcon = new SqlConnection(strCon);//创建链接对象
            sqlda = new SqlDataAdapter("select name as 用户名称 from userphoto", sqlcon);//查询SQL
            myds = new DataSet();//填充数据集
            sqlda.Fill(myds);
            dataGridView1.DataSource = myds.Tables[0];//显示
        }
        #endregion

********************************************************

#region 显示用户信息
        /// <summary>
        /// 显示用户头像
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e)
        {
            //记录选择的用户名
            string strName = dataGridView1.Rows[e.RowIndex].Cells[0].Value.ToString().Trim();
            if (strName != "")
            {
                sqlcon = new SqlConnection(strCon);     //实例化数据库连接对象
                //实例化数据桥接器对象
                sqlda = new SqlDataAdapter("select * from userphoto where name='" + strName + "'", sqlcon);
                myds = new DataSet();                   //实例化数据集对象
                sqlda.Fill(myds);                       //填充数据集
                //显示用户名称
                textBox1.Text = myds.Tables[0].Rows[0][1].ToString();
                //使用数据库中存储的二进制头像实例化内存数据流
                MemoryStream MStream = new MemoryStream((byte[])myds.Tables[0].Rows[0][2]);
                pictureBox1.Image = Image.FromStream(MStream);  //显示用户头像
            }
        }
        #endregion

文章出处:https://blog.csdn.net/paullink520/article/details/19563881

Winform下如何上传图片并显示出来。同时保存到数据库的更多相关文章

  1. C#(WinForm)上传图片保存到数据库和从数据库读取图片显示到窗体

    //浏览图片 private void btnUp_Click(object sender, EventArgs e) { OpenFileDialog ofd = new OpenFileDialo ...

  2. C# winform 窗体应用程序之图片上传Oracle数据库保存字段BLOB

    C# winform 窗体应用程序之图片上传Oracle数据库保存字段BLOB 我用的数据库是Oracle,就目前来看,许多数据库现在都倾向于Oracle数据库,对ORACLE数据库基本的操作也是必须 ...

  3. Winform下CefSharp的引用、配置、实例与报错排除(源码)

    Winform下CefSharp的引用.配置.实例与报错排除 本文详细介绍了CefSharp在vs2013..net4.0环境下,创建Winfrom项目.引用CefSharp的方法,演示了winfro ...

  4. php实现上传图片保存到数据库的方法

    http://www.jb51.net/article/61034.htm 作者:傲雪星枫 字体:[增加 减小] 类型:转载   这篇文章主要介绍了php实现上传图片保存到数据库的方法,可通过将图片保 ...

  5. C# LIstbox 解决WinForm下ListBox控件“设置DataSource属性后无法修改项集合”的问题

    解决WinForm下ListBox控件“设置DataSource属性后无法修改项集合”的问题 分类: winform2008-05-24 02:33 2592人阅读 评论(11) 收藏 举报 winf ...

  6. 解决WinForm下ListBox控件“设置DataSource属性后无法修改项集合”

    解决WinForm下ListBox控件“设置DataSource属性后无法修改项集合” 最近更新: 2013-2-15    587   很少写WinForm程序第一次使用ListBox控件就遇到了比 ...

  7. 分享在winform下实现模块化插件编程-优化版

    上一篇<分享在winform下实现模块化插件编程>已经实现了模块化编程,但我认为不够完美,存在以下几个问题: 1.IAppContext中的CreatePlugInForm方法只能依据完整 ...

  8. 分享在winform下实现模块化插件编程

    其实很早之前我就已经了解了在winform下实现插件编程,原理很简单,主要实现思路就是:先定一个插件接口作为插件样式及功能的约定,然后具体的插件就去实现这个插件接口,最后宿主(应用程序本身)就利用反射 ...

  9. 分享在winform下实现左右布局多窗口界面-续篇

    之前的这篇文章<分享在winform下实现左右布局多窗口界面>已经实现了左右布局多窗口界面,今天本来是研究基于winform的插件编程,没想到顺便又找到了另一种实现方案,这种实现方案更简单 ...

随机推荐

  1. linux:nano 、cat和file

    nano 在 Linux 下面编辑文件通常我们会直接使用专门的命令行编辑器比如(emacs,vim,nano),涉及 Linux 上的编辑器的内容比较多,且非常重要. nano 是 linux 的一款 ...

  2. centos6.5(64bit),python2.6.6安装MySQLdb模块

    1.下载MySQL-python.setuptools安装包 2.tar zxvf setuptools-0.6c11.tar.gz 3.cd setuptools-0.6c11 4.python s ...

  3. 2014年蓝桥杯省赛A组c++第2题(推公式)

    /* 标题:切面条 一根高筋拉面,中间切一刀,可以得到2根面条. 如果先对折1次,中间切一刀,可以得到3根面条. 如果连续对折2次,中间切一刀,可以得到5根面条. 那么,连续对折10次,中间切一刀,会 ...

  4. kafka读书笔记《kafka权威指南》2018

    1.有了分区,可以多个client消费一个topic,有了分区,可以将一个topic 分散在多个broker 2.kafka通过复制实现可靠,通过横向扩展提高性能(如增加分区.客户端.增加broker ...

  5. TableView刷新跳动问题

    https://juejin.im/post/5aca1a04f265da2391486533 解决办法: 将估算高度设置为0即可: tableView.estimatedRowHeight = 0; ...

  6. 第三方python 加密库 --- cryptography

    1,安装依赖 pip install cryptography 2,生成秘钥 from cryptography.fernet import Fernet #秘钥#随机生成秘钥 cipher_key ...

  7. Python开发【异步】:asyncio

    异步asyncio asyncio是一个使用async / await语法编写并发代码的库. asyncio用作多个Python异步框架的基础,这些框架提供高性能的网络和Web服务器,数据库连接库,分 ...

  8. flex布局 响应式布局

    移动端页面开发流程   移动端页面布局 一.移动端app分类 1.Native App原生app手机应用程序 使用原生的语言开发的手机应用,Android系统用的是java,ios系统用的是objec ...

  9. MySQL中死锁(转)

    add by zhj: 总结一下,MySQL有主动和被动两种方式检测死锁. 主动方式:检查锁等待的图,如果有环,那就有死锁,这种情况下,会回滚事务. 被动方式:等待锁超时(即innodb_lock_w ...

  10. Apache Spark支持三种分布式部署方式 standalone、spark on mesos和 spark on YARN区别

    链接地址: http://dongxicheng.org/framework-on-yarn/apache-spark-comparing-three-deploying-ways/ Spark On ...