C# ArrayList序列化到数据库并读取
需积分: 9 27 浏览量
更新于2024-09-12
收藏 3KB TXT 举报
C# ArrayList 是.NET Framework中的一种动态数组类型,它允许在运行时添加、删除和修改元素,非常适合处理一系列不固定长度的数据。在这个给定的代码片段中,主要展示了如何将ArrayList对象插入到数据库中,并通过序列化和反序列化进行数据传输。
首先,`ArrayList ar = new ArrayList();` 创建了一个名为`ar`的新ArrayList实例,用于存储IP地址。这个ArrayList被初始化为包含三个元素:"192.168.1.7", "192.168.1.5", 和 "192.168.1.4",这些IP地址可能是数据库中的某个表的记录。
为了将ArrayList保存到数据库,代码使用了`BinaryFormatter`来序列化ArrayList。`BinaryFormatter`是.NET提供的一个用于序列化和反序列化.NET对象的工具。`MemoryStream ms = new MemoryStream();` 创建了一个内存流对象,`form.Serialize(ms, ar);` 将ArrayList `ar` 序列化并写入内存流中。序列化后的数据存储在`byte[] by = ms.ToArray();` 中,这样可以将其转换为字节数组,方便数据库操作。
接着,通过获取登录用户的IP地址,代码执行SQL插入操作,其中使用了`BF.DAL_Indata.ExecuteIndata`方法,这可能是一个自定义的数据库操作方法,参数包括登录代码(`login.code`)、字符串关键字(`keyword`)等。将序列化的ArrayList数据以`by`的形式插入到指定表的特定字段中,这里假设字段类型可以接受字节数组。
执行完插入操作后,`DataTable da = BF.DAL_Indata.GetDataTable` 方法用来获取刚刚插入的数据,通过查询结果的第0行第0个字段,获取到刚才插入的字节数组。接着,用`MemoryStream ms1 = new MemoryStream(sth);` 创建一个新的内存流,将查询结果解序列化回ArrayList,赋值给`ArrayList ast = (ArrayList)form.Deserialize(ms1);`。
最后,通过循环遍历ArrayList `ast`,使用`listBox1.Items.Add(string.Format("{0}", (string)ast[i]));` 将序列化后的IP地址添加到名为`listBox1`的控件中,供用户查看。
总结来说,这段代码展示了C#中ArrayList的使用以及如何通过序列化和反序列化技术将ArrayList数据存储到数据库,然后从数据库中检索并展示出来。这种做法常用于需要灵活存储和处理大量不规则数据的情况,且在跨平台或网络传输数据时非常有用。
2008-11-11 上传
2010-04-06 上传
2023-07-28 上传
2024-05-01 上传
2023-07-29 上传
2023-08-24 上传
2023-05-17 上传
2023-04-19 上传
u010772944
- 粉丝: 0
- 资源: 1
最新资源
- JHU荣誉单变量微积分课程教案介绍
- Naruto爱好者必备CLI测试应用
- Android应用显示Ignaz-Taschner-Gymnasium取消课程概览
- ASP学生信息档案管理系统毕业设计及完整源码
- Java商城源码解析:酒店管理系统快速开发指南
- 构建可解析文本框:.NET 3.5中实现文本解析与验证
- Java语言打造任天堂红白机模拟器—nes4j解析
- 基于Hadoop和Hive的网络流量分析工具介绍
- Unity实现帝国象棋:从游戏到复刻
- WordPress文档嵌入插件:无需浏览器插件即可上传和显示文档
- Android开源项目精选:优秀项目篇
- 黑色设计商务酷站模板 - 网站构建新选择
- Rollup插件去除JS文件横幅:横扫许可证头
- AngularDart中Hammock服务的使用与REST API集成
- 开源AVR编程器:高效、低成本的微控制器编程解决方案
- Anya Keller 图片组合的开发部署记录