以对象的方式来访问xml数据表(一)
所有实例代码都是以C#演示——
在将如何以对象的方式来访问xml数据表之前,我们先来谈谈如何用xml文件作为数据库吧!
平时在开发一些小的应用的时候,需要一个数据库,这个时候虽然可以用SQL server、MySql等第三方数据库,但个人感觉这有点大材小用、而且配置链接起来还很麻烦,这个时候就可以考虑使用xml文件作为数据库,小巧、方便打包。
先简单的举一个例子:用一个xml文件来保存用户信息(用户可以有多个)
<?xml version="1.0" encoding="utf-8"?>
<Users>
<User>
<Id>1</Id>
<Name>forcheng</Name>
<Password>123456</Password>
<IsAdmin>1</IsAdmin>
<DateCreated>2016/03/22 16:08:00</DateCreated>
</User>
<User>
<Id>2</Id>
<Name>cheng</Name>
<Password>123456789</Password>
<IsAdmin>0</IsAdmin>
<DateCreated>2016/03/24 12:08:30</DateCreated>
</User>
</Users>
通过上面的xml代码,我们知道了数据是如何保存在xml文件里面的。(在这里,你可以简单将一个xml文件看做一张数据表,每一个<user>...</user>元素看做是一条记录)
下面的实例简单地展示一下如何对xml文件中的数据进行增、删、查、改操作:
using System;
using System.IO;
using System.Xml.Linq;
using System.Linq; namespace ConsoleApplication
{ class Program
{
//主函数
static void Main(string[] args)
{
//如果不存在文件,则先创建
if(!File.Exists("db.xml"))
{
var xmlFile = new StreamWriter("db.xml");
xmlFile.WriteLine("<?xml version=\"1.0\" encoding=\"utf-8\"?>");
xmlFile.WriteLine("<Users>");
xmlFile.WriteLine("</Users>");
xmlFile.Close();
} XElement xmlDoc = XElement.Load("db.xml");//载入db.xml文件,db.xml与可执行程序位于同一目录 Console.WriteLine(xmlDoc.ToString());//输出显示数据
Console.WriteLine();
Console.ReadKey(); ///给db.xml添加数据/// //创建两条记录
XElement newNode1 = new XElement("User",
new XElement("Id",""),
new XElement("Name", "川"),
new XElement("Password", ""),
new XElement("IsAdmin", ""),
new XElement("DateCreated", DateTime.Now.ToString())
);
XElement newNode2 = new XElement("User",
new XElement("Id", ""),
new XElement("Name", "龙"),
new XElement("Password", ""),
new XElement("IsAdmin", ""),
new XElement("DateCreated", DateTime.Now.ToString())
);
xmlDoc.Add(newNode1);//添加记录newNode1
xmlDoc.Add(newNode2);//添加记录newNode2,此时数据并未直接保存在db.xml文件里面而是保存在缓存或其他地方,想要将修改后的数据保存,需调用 Save() 方法 //xmlDoc.Save("db.xml");保存修改到文件
Console.WriteLine(xmlDoc.ToString());//输出显示数据
Console.WriteLine();
Console.ReadKey(); ///修改db.xml里面的数据/// var allUses = xmlDoc.Elements("User") ;//返回所有用户数据(引用) var first = allUses.First();//获取第一个元素 等价于allUses.ElementAt(0)
first.Element("Name").Value = "小明"; var second = allUses.ElementAt();//获取第二个元素
second.Element("Password").Value = ""; //xmlDoc.Save("db.xml");保存修改到文件
Console.WriteLine(xmlDoc.ToString());//输出显示数据
Console.WriteLine();
Console.ReadKey(); ///遍历db.xml里面的数据///
///
foreach (var item in xmlDoc.Elements("User"))
{
Console.WriteLine(item.Element("Id").Value);
Console.WriteLine(item.Element("Name").Value);
Console.WriteLine(item.Element("Password").Value);
Console.WriteLine(item.Element("IsAdmin").Value);
Console.WriteLine(item.Element("DateCreated").Value);
}
Console.WriteLine(); ///删除db.xml里面的数据/// newNode1.Remove();//移除数据 等价于 first.Remove(); 因为它们都是实例的引用
newNode2.Remove();//移除数据 等价于 second.Remove();
//上面两句也等价于 xmlDoc.RemoveAll(); 移除所有子节点和属性 //xmlDoc.Save("db.xml");保存修改到文件
Console.WriteLine(xmlDoc.ToString());//输出显示数据
Console.ReadKey();
}
}
}
看了上面的源代码的读者可能发现,源代码中并没有涉及以对象的方式来访问xml数据表,不用急。写上面的源代码主要目的有两个:(一)、展示一下对xml文件中的数据进行增、删、查、改等基本操作,让读者有一个大概了解。(二)、为了引出以对象的方式来访问xml数据表的方便和后期维护的高效性,大家看了上面的对xml元素的访问方式之后,是否觉得每次都要通过Element(value)去访问元素的值很不方便?。(可能没有用过xml文件作为数据库开发的并不会认为这有什么不方便之处)。
那么我将在(二)、(三)中详细谈到为什么要用以对象的方式来访问xml数据表和怎样以对象的方式来访问xml数据表。
以对象的方式来访问xml数据表(一)的更多相关文章
- 以对象的方式来访问xml数据表(三)
怎样以对象的方式来访问xml数据表? 在讲如何具体实现(二)中所说的专门用于访问xml文件的动态链接库之前,我们先来看看这个动态链接库具体要实现什么功能. 动态链接库IXmlDB.dll的功能: 1. ...
- 以对象的方式来访问xml数据表(二)
为什么要以对象的方式来访问xml数据表? 还记得,自己是在一次完成师兄布置的任务时接触到了xml,那时候需要用xml来作为数据文件,保存一个简单的图书管理系统的数据.于是就知道了,可以用xml文件来保 ...
- Ajax跨域访问XML数据的另一种方式——使用YQL查询语句
XML数据默认是不能在客户端通过Ajax跨域请求读取的,一般的做法是在服务器上写一个简单的代理程序,将远程XML的数据先读到本地服务器,然后客户端再从本地服务器通过Ajax来请求.由于我们不能对数据源 ...
- wcf序列化大对象时报错:读取 XML 数据时,超出最大
错误为: 访问服务异常:格式化程序尝试对消息反序列化时引发异常: 尝试对参数 http://tempuri.org/ 进行反序列化时出 错: request.InnerException 消息是“反序 ...
- 使用Entity Framework通过code first方式创建数据库和数据表
开发环境 WIN10 Entity Framework6.0 MVC5.0 开发工具 VS2015 SqlServer2012 1.创建上下文Context继承DbContext,并创建其他的业 ...
- SpringMVC06以对象的方式获取前台的数据
========创建需要的两个实体类================ public class School { private String sName; private String addres ...
- 使用JavaScript访问XML数据
在本篇文章中,我们将讲述如何在IE中使用ActiveX功能来访问并解析XML文档,由此允许网络冲浪者操纵它们.这一网页将传入并运行脚本的初始化.你一定确保order.xml文档与jsxml.html在 ...
- hibernate中.hbm.xml和注解方式自动生成数据表的简单实例(由新手小白编写,仅适用新手小白)
绝逼新手小白,so 请大神指点! 如果真的错的太多,错的太离谱,错的误导了其他小伙伴,还望大神请勿喷,大神请担待,大神请高抬贵嘴......谢谢. 好了,正题 刚接触ssh,今天在搞使用.hbm.xm ...
- Android开发之使用DefaultHandler处理XML数据
一.定义规则 XML数据结构定义 请记住上面的定义,后面我会用“标签开始”.“文本”.“标签结束”表示SAX正在处理哪部分XML数据 事件模型 为什么这里我要谈到这个,因为SAX处理XML数据是采用事 ...
随机推荐
- Nodejs开源项目推荐
当我们学习一门新语言,不要用以前语言的习惯去使用新的语言,这样可能会导致走一些弯路.最好的办法就是去看一些写的比较好的开源项目,所以这里我推荐几个NodeJs的开源项目,花点时间去研究一下他们的实现, ...
- java利用透明的图片轮廓抠图
需要处理的图片: 1.png(空白区域为透明) 2.png 处理后的结果图片:result.png 代码如下: import java.awt.Graphics2D; import java.awt. ...
- 【经验谈】XmlSerializer的坑
XmlSerializer我想现在用的人可能不多了,大家都在用Json.我现在所在的公司依然在用,所以发现了这个坑.当然这个坑存在很久了只是没用过所以才发现. 事情是这样的,测试那边说系统偶尔会报找不 ...
- python 跳出嵌套循环方法
class LoopError(Exception):pass rs = '' try: for i in range(1, 3): print i rs = 'one ' if i == 1: fo ...
- sqlite3基础
要使用sqlite,首先需要添加库文件libsqlite3.dylib.当你搜索libsqlite3关键字时,会发现还有一个libsqlite3.0.dylib的库文件,这里还是建议添加libsqli ...
- POJ 3903 Stock Exchange
Stock Exchange Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 2954 Accepted: 1082 De ...
- WindowsServer2012桌面图标设置
1.win+R调出运行窗口 2.输入:rundll32.exe shell32.dll,Control_RunDLL desk.cpl,,0 即可
- haproxy 配置
1.环境: 操作系统:CentOS 6.4 haproxy: 1.3.15.10 [下载:http://download.chinaunix.net/download.php?id=25784& ...
- 解决“iOS 7 app自动更新,无法在app中向用户展示更新内容”问题
转自cocoachina iOS 7能在后台自动app,这对开发者来说和用户都很方便,但是还是有一些缺点.用户不会知道app本次更新的内容,除非他们上到app的App Store页面去查看.开发者也会 ...
- zeromq 测试总结
总结 测试项目 github (https://github.com/solq360/jmzq) 非常不稳定 pub/sub 模式 30W压测丢了27W条消息,官方没有给出任何的发送状态供业务层处理 ...