C#操作本地文件及保存文件到数据库的基本方法总结
更新时间:2020年6月25日 11:24 点击:3969
命名空间:
using System.IO;
写文本文件
StreamWriter sw=File.CreateText("c:\\text.txt"); sw.WriteLine("C#"); //写入一行文本 sw.Write("www.csdn.net"); //在文本末尾写入文本 sw.Flush(); //清空 sw.Close(); //关闭
读文本文件
StreamReader sr = File.OpenText("c:\\text.txt"); sr.ReadLine(); //读取一行数据 sr.Read(); //读取一个字符 sr.ReadToEnd(); //从当前位置读取到文本结束 sr.Close(); //释放资源
追加文本文件
StreamWriter sw = File.AppendText("c:\\text.txt"); sw.WriteLine("C#"); //写入一行文本 sw.Write("www.csdn.net"); //在文本末尾写入文本 sw.Flush(); //清空 sw.Close(); //关闭
判断文件是否存在
File.Exists("c:\\text.txt");
删除文件
File.Delete("c:\\text.txt");
复制文件
File.Copy("c:\\text.txt", "c:\\copy.txt"); //把c:\\text.txt复制到c:\\copy.txt
移动文件
File.Copy("c:\\text.txt", "d:\\text.txt"); //把c:\\text.txt移动到d:\\text.txt
文件夹创建、移动、删除
Directory.Delete("c:\\test"); //删除C盘下的test文件夹 Directory.CreateDirectory("c:\\test"); //在C盘创建test文件夹 Directory.Exists("c:\\test"); //验证C盘test文件夹是否存在 Directory.Move("c:\\test", "d:\\test"); //把c:\test移动到d:\test
Oracle数据库中保存文件(C#)
Oracle中有Blob和Clob可以保存大数据量。其中Blob是指二进制大对象也就是英文Binary Large Object的缩写,用来存储大量二进制数据。而Clob是指大字符对象是英文Character Large Object的缩写,用来存储大量文本数据。
1.数据库表
-- 创建文件表
create table tb_file ( id number(20) not null, file_name nvarchar2(100), file_content blob, constraint pk_tb_file primary key (id) ) tablespace mydb storage( initial 64K minextents 1 maxextents unlimited );
--设置tb_file主键自增
create sequence seq_tb_file --创建自增序列 minvalue 1 maxvalue 9999999999999999999 start with 1 increment by 1 nocache order; create or replace trigger ai_tb_file --创建触发器,当插入新记录时自增主键id before insert on tb_file for each row when (new.id is null) begin select seq_tb_file.nextval into :new.id from dual; end;
2 在数据库中保存和读取二进制文件
//添加命名空间 using System; using System.Data.OracleClient; using System.IO; using System.Data; /// <summary> /// 把文件插入数据库中 /// </summary> /// <param name="filePath">文件名,包含路径,如c:\temp.rar</param> /// <returns></returns> public int Insert(string filePath) { string connStr = "data source=orcl;user=mydbuser;password=mydbuser;"; OracleConnection conn = new OracleConnection(connStr); OracleCommand cmd = conn.CreateCommand(); //读取文件 FileStream fs = File.OpenRead(filePath); byte[] buffer = new byte[fs.Length]; fs.Read(buffer, 0, buffer.Length); OracleParameter paramFileContent = cmd.CreateParameter(); paramFileContent.OracleType = OracleType.Blob; paramFileContent.ParameterName = "FileContent"; paramFileContent.Direction = ParameterDirection.Input; paramFileContent.Value = buffer; cmd.Parameters.Add(paramFileContent); OracleParameter paramFileName = cmd.CreateParameter(); paramFileName.OracleType = OracleType.VarChar; paramFileName.ParameterName = "FileName"; paramFileName.Direction = ParameterDirection.Input; paramFileName.Value = Path.GetFileName(filePath); cmd.Parameters.Add(paramFileName); string sqlInsert = "insert into tb_file (file_name, file_content) values (:FileName, :FileContent)"; cmd.CommandText = sqlInsert; cmd.CommandType = CommandType.Text; conn.Open(); int result = cmd.ExecuteNonQuery(); conn.Close(); return result; } /// <summary> /// 根据文件名从数据库中获取文件 /// </summary> /// <param name="fileName">数据库中的文件名</param> /// <param name="savePath">文件的保存路径,包括文件名,如c:\file.rar</param> public void Select(string fileName, string savePath) { string connStr = "data source=orcl;user=mydbuser;password=mydbuser;"; OracleConnection conn = new OracleConnection(connStr); OracleCommand cmd = conn.CreateCommand(); string sqlSelect = "select file_name, file_content from tb_file where file_name=:FileName"; cmd.CommandText = sqlSelect; cmd.CommandType = CommandType.Text; OracleParameter paramFileName = cmd.CreateParameter(); paramFileName.OracleType = OracleType.VarChar; paramFileName.ParameterName = "FileName"; paramFileName.Direction = ParameterDirection.Input; paramFileName.Value = fileName; cmd.Parameters.Add(paramFileName); conn.Open(); OracleDataReader dr = cmd.ExecuteReader(); dr.Read(); byte[] buffer = (byte[])dr["file_content"]; dr.Close(); conn.Close(); //把文件保存到指定路径 File.WriteAllBytes(savePath, buffer); }
下一篇: C#的Excel导入、导出
相关文章
- 下面小编来给大家演示几个php操作zip文件的实例,我们可以读取zip包中指定文件与删除zip包中指定文件,下面来给大这介绍一下。 从zip压缩文件中提取文件 代...2016-11-25
- 我们在使用C#做项目的时候,基本上都需要制作登录界面,那么今天我们就来一步步看看,如果简单的实现登录界面呢,本文给出2个例子,由简入难,希望大家能够喜欢。...2020-06-25
- 这篇文章主要介绍了C# 字段和属性的的相关资料,文中示例代码非常详细,供大家参考和学习,感兴趣的朋友可以了解下...2020-11-03
- 操作类就是把一些常用的一系列的数据库或相关操作写在一个类中,这样调用时我们只要调用类文件,如果要执行相关操作就直接调用类文件中的方法函数就可以实现了,下面整理了...2016-11-25
- 这篇文章主要介绍了C#中截取字符串的的基本方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-11-03
Jupyter Notebook读取csv文件出现的问题及解决
这篇文章主要介绍了JupyterNotebook读取csv文件出现的问题及解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2023-01-06- 这篇文章主要介绍了C#实现简单的Http请求的方法,以实例形式较为详细的分析了C#实现Http请求的具体方法,需要的朋友可以参考下...2020-06-25
- 本文给大家分享C#连接SQL数据库和查询数据功能的操作技巧,本文通过图文并茂的形式给大家介绍的非常详细,需要的朋友参考下吧...2021-05-17
- 本文主要介绍了C#中new的几种用法,具有很好的参考价值,下面跟着小编一起来看下吧...2020-06-25
使用Visual Studio2019创建C#项目(窗体应用程序、控制台应用程序、Web应用程序)
这篇文章主要介绍了使用Visual Studio2019创建C#项目(窗体应用程序、控制台应用程序、Web应用程序),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2020-06-25- 这篇文章主要介绍了C#开发Windows窗体应用程序的简单操作步骤,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-04-12
- 这篇文章主要介绍了C#从数据库读取图片并保存的方法,帮助大家更好的理解和使用c#,感兴趣的朋友可以了解下...2021-01-16
- 最近做一个小项目不可避免的需要前端脚本与后台进行交互。由于是在asp.net中实现,故问题演化成asp.net中jiavascript与后台c#如何进行交互。...2020-06-25
- 本文通过例子,讲述了C++调用C#的DLL程序的方法,作出了以下总结,下面就让我们一起来学习吧。...2020-06-25
- 轻松学习C#的基础入门,了解C#最基本的知识点,C#是一种简洁的,类型安全的一种完全面向对象的开发语言,是Microsoft专门基于.NET Framework平台开发的而量身定做的高级程序设计语言,需要的朋友可以参考下...2020-06-25
- 本文主要介绍了C#变量命名规则小结,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-09
- 这篇文章主要介绍了C#绘制曲线图的方法,以完整实例形式较为详细的分析了C#进行曲线绘制的具体步骤与相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
- 本文主要介绍了C# 中取绝对值的函数。具有很好的参考价值。下面跟着小编一起来看下吧...2020-06-25
- 这篇文章主要介绍了c#自带缓存使用方法,包括获取数据缓存、设置数据缓存、移除指定数据缓存等方法,需要的朋友可以参考下...2020-06-25
- 这篇文章主要介绍了c#中(&&,||)与(&,|)的区别详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-06-25