C# 读写ACCESS的OLE对象,演示图片与长文件的读写

2010021512020698.gif

网络上的读写OLE对象的代码是多,不过多是转载的,大部分人从来都没实际测试过,只是COPY来COPY去。我重来没看到一个真正可以运行的东东。
没办法,只有自力更生,花了一点时间出了点研究成果,写到这里做个记录。

关键代码如下:

******* void button1_Click(object sender, EventArgs e)  //写入图片
        {
            OpenFileDialog dlg = new OpenFileDialog();
            dlg.Filter = "All   Files|*.*";
            if (dlg.ShowDialog() == DialogResult.OK)
            {
                string fileName = dlg.FileName;

                FileStream fs = new FileStream(fileName, FileMode.Open, FileAccess.Read);
                byte[] buffer = new byte[fs.Length];
                fs.Read(buffer, 0, buffer.Length);
                fs.Close();

                //pictureBox1.Image = Image.FromFile(fileName);

                OleDbConnection cn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Application.StartupPath + "\\db1.mdb" + ";Persist Security Info=True");
                cn.Open();

                OleDbCommand cmd = new OleDbCommand("INSERT INTO  list1(pic)  VALUES(@img)", cn);
                ((OleDbParameter)cmd.Parameters.Add("@img", OleDbType.Binary)).Value = buffer;
                cmd.ExecuteNonQuery();
            }  
 

          
    }

        ******* void button2_Click(object sender, EventArgs e)  //读取图片
        {
            OleDbConnection cn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Application.StartupPath + "\\db1.mdb" + ";Persist Security Info=True");
            cn.Open();

            OleDbDataAdapter oda = new OleDbDataAdapter("select  pic  from  list1 where 编号=10", cn);
           

            DataTable dt = new DataTable();
            oda.Fill(dt);

            cn.Close();

            byte[] buffer = dt.Rows[0][0] as byte[];
            MemoryStream ms = new MemoryStream(buffer);

            pictureBox1.Image = Image.FromStream(ms);
        }

        ******* void button3_Click(object sender, EventArgs e)  //写入长文本
        {
            OpenFileDialog dlg = new OpenFileDialog();
            dlg.Filter = "TXT Files|*.txt";
            if (dlg.ShowDialog() == DialogResult.OK)
            {
                string fileName = dlg.FileName;

                FileStream fs = new FileStream(fileName, FileMode.Open, FileAccess.Read);
                byte[] buffer = new byte[fs.Length];
                fs.Read(buffer, 0, buffer.Length);
                fs.Close();

                //pictureBox1.Image = Image.FromFile(fileName);

                OleDbConnection cn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Application.StartupPath + "\\db1.mdb" + ";Persist Security Info=True");
                cn.Open();

                OleDbCommand cmd = new OleDbCommand("INSERT INTO  list1(pic)  VALUES(@img)", cn);
                ((OleDbParameter)cmd.Parameters.Add("@img", OleDbType.Binary)).Value = buffer;
                cmd.ExecuteNonQuery();
            }  
        }

        ******* void button4_Click(object sender, EventArgs e)  //载入长文本
        {
            OleDbConnection cn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Application.StartupPath + "\\db1.mdb" + ";Persist Security Info=True");
            cn.Open();

            OleDbDataAdapter oda = new OleDbDataAdapter("select  pic  from  list1 where 编号=12", cn);

            DataTable dt = new DataTable();
            oda.Fill(dt);

            cn.Close();

            byte[] buffer = dt.Rows[0][0] as byte[];
            //MemoryStream ms = new MemoryStream(buffer);
            richTextBox1.Text =System.Text.Encoding.Default.GetString(buffer);


        }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用C#中的ADOX(ActiveX Data Objects Extensibility Library)来读写Access数据库。X是一个COM库,提供了一组用于管理数据库架构的对象和方法。下面是一个简单的示例,演示如何使用ADOX来创建一个新的Access数据库,并在其中创建一个表并插入数据: ```csharp using ADOX; using ADODB; // 创建新的Access数据库 Catalog catalog = new Catalog(); catalog.Create("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\\path\\to\\database.mdb;Jet OLEDB:Engine Type=5"); // 连接到已存在的Access数据库 //Catalog catalog = new Catalog(); //catalog.let_ActiveConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\\path\\to\\database.mdb"); // 创建新的表 Table table = new Table(); table.Name = "MyTable"; table.Columns.Append("ID", DataTypeEnum.adInteger, 10); table.Columns.Append("Name", DataTypeEnum.adVarWChar, 50); table.Keys.Append("PrimaryKey", KeyTypeEnum.adKeyPrimary, "ID", "", ""); catalog.Tables.Append(table); // 插入数据 Connection connection = new Connection(); connection.Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\\path\\to\\database.mdb"); Recordset recordset = new Recordset(); recordset.Open("SELECT * FROM MyTable", connection, CursorTypeEnum.adOpenDynamic, LockTypeEnum.adLockOptimistic); recordset.AddNew(); recordset.Fields["ID"].Value = 1; recordset.Fields["Name"].Value = "John"; recordset.Update(); recordset.Close(); connection.Close(); ``` 请注意,你需要先安装Microsoft Access Database Engine(链接:https://www.microsoft.com/en-us/download/details.aspx?id=13255)来使用ADOX操作Access数据库。另外,如果你要连接到已存在的Access数据库,可以使用`Catalog`对象的`let_ActiveConnection`方法来指定连接字符串。 希望这个示例能帮助你开始使用ADOX在C#读写Access数据库!如有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值