Db4o数据库:细说查询[通俗易懂]

Db4o数据库:细说查询[通俗易懂]通过第一篇的介绍,相信大家也对Db4o有一定的了解,接下来就详细说一下有关查询的话题。Db4o原生支持3中查询模式:Query-By-Example:简称QBE,根据模板类进行匹配查询,这是最简单的一种模式NativeQuery:简称NQ,Db4o推荐的查询模式TheSODAAPI:这是Db4o底层查询API,官网文档解释,此API提供向后的兼容性,适用于动态

大家好,又见面了,我是你们的朋友全栈君。

通过第一篇的介绍,相信大家也对Db4o有一定的了解,接下来就详细说一下有关查询的话题。

Db4o原生支持3中查询模式:

  • Query-By-Example: 简称 QBE ,根据模板类进行匹配查询,这是最简单的一种模式
  • Native Query: 简称 NQ ,Db4o推荐的查询模式
  • The SODA API :这是Db4o底层查询API ,官网文档解释,此API提供向后的兼容性,适用于动态生成的查询
此外,.Net平台还可以通过LINQ进行快速的查询。

准备测试数据


下面给出一个职工类

	/// <summary>
	/// 职工
	/// </summary>
	class Employee
	{
		/// <summary>
		/// 姓名
		/// </summary>
		string _name;
		public string Name
		{
			set { _name = value; }
			get { return _name; }
		}

		/// <summary>
		/// 职位
		/// </summary>
		public Position Position { get; set; }

		public override string ToString()
		{
			return string.Format("姓名:{0},职位:{1}",this.Name,this.Position.PositionName);
		}
	}

	/// <summary>
	/// 职位
	/// </summary>
	class Position
	{
		/// <summary>
		/// 职称
		/// </summary>
		public string PositionName { get; set; }
	}

填充测试数据

		static List<Employee> GetEmployee()
		{
			List<Employee> _Employees = new List<Employee>();
			Employee _Employee = new Employee { Name = "Sunth", Position = new Position { PositionName = "CEO" } };
			_Employees.Add(_Employee);
			_Employee = new Employee { Name = "Jerry", Position = new Position { PositionName = "CTO" } };
			_Employees.Add(_Employee);
			_Employee = new Employee { Name = "Tom", Position = new Position { PositionName = "COO" } };
			_Employees.Add(_Employee);
			return _Employees;
		}

Query-By-Example


一种非常简单直观的查询方式,通过模板进行对比查询,比如说查一个名为Sunth的职工信息

		static void Main(string[] args)
		{
			string DbPath = "Pilot.yap";
			if (File.Exists(DbPath))
				File.Delete(DbPath);
			using (IObjectContainer Container = Db4oEmbedded.OpenFile(DbPath))
			{
				//对数据库进行初始化,并存入测试数据
				var Query = GetEmployee();
				Query.ForEach
					(
						(a) => { Container.Store(a); }
					);

				//查询一个叫做Sunth的职工
				Employee _Employee = new Employee();
				_Employee.Name = "Sunth";
				IObjectSet Result = Container.QueryByExample(_Employee);
				//打印结果
				PrintResult(Result);
			}
			Console.ReadKey();
		}
大家是否明白了QueryByExample()这个方法名的含义,根据你所给出指定类型的模板,Db4o进行属性值匹配查询。如果模板中属性被没有赋值,Db4o自动取默认值当做条件。如果想查询所有匹配此类型的数据,只需要实例化一个Employee对象,当做参数,传入就OK。
这种方法虽然很简单,但是它有很大的局限性,比如你不能直接使用 and , or ,like 等操作

NativeQuery


这是Db4o推荐的查询方式,但在.Net平台还是比较推荐使用LINQ的。还是那个例子,查询一个名为Sunth的职工信息
		static void Main(string[] args)
		{
			string DbPath = "Pilot.yap";
			if (File.Exists(DbPath))
				File.Delete(DbPath);
			using (IObjectContainer Container = Db4oEmbedded.OpenFile(DbPath))
			{
				//对数据库进行初始化,并存入测试数据
				var Query = GetEmployee();
				Query.ForEach
					(
						(a) => { Container.Store(a); }
					);

				//查询一个叫做Sunth的职工
				Employee _Employee = new Employee();
				var Result = Container.Query<Employee>
					(
						delegate(Employee employee)
						{
							return employee.Name == "Sunth";
						}
					);
				//打印结果
				PrintResult(Result);
			}
			Console.ReadKey();
		}
这样是不是灵活性更高点了呢。

The SODA API


Db4o底层的查询方式,使用便捷度肯定不如前两种,但是了解是必须的,当遇到不可解决的问题时,这可能就是一思路。
查询一个名为Sunth的职工信息,具体的注释请看代码

		static void Main(string[] args)
		{
			string DbPath = "Pilot.yap";
			if (File.Exists(DbPath))
				File.Delete(DbPath);
			using (IObjectContainer Container = Db4oEmbedded.OpenFile(DbPath))
			{
				//对数据库进行初始化,并存入测试数据
				var Query = GetEmployee();
				Query.ForEach
					(
						(a) => { Container.Store(a); }
					);

				//查询一个叫做Sunth的职工
				IQuery _IQuery = Container.Query();
				//强制约束Employee类型
				_IQuery.Constrain(typeof(Employee));
				//注意此“_name”为字段名称,非属性名称
				_IQuery.Descend("_name").Constrain("Sunth");
				//执行查询
				IObjectSet Result = _IQuery.Execute();
				//打印结果
				PrintResult(Result);
			}
			Console.ReadKey();
		}

结束语


说了Db4o原生支持的查询方式,而这些是最基本的,在以后的文章里,我们必定会用到更加繁琐的查询。
刚开始写系列文章,在语言组织方面还是一大缺陷,请大家多多原谅,祝大家生活幸福。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/162575.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Idea激活码永久有效Idea2019.3.2激活码教程-持续更新,一步到位

    Idea激活码永久有效Idea2019.3.2激活码教程-持续更新,一步到位Idea激活码永久有效2019.3.2激活码教程-Windows版永久激活-持续更新,Idea激活码2019.3.2成功激活

    2022年6月17日
    87
  • java 卸载_java安装与卸载[通俗易懂]

    java 卸载_java安装与卸载[通俗易懂]1.安装JDK进行安装,安装过程中会有两次选择安装目录的时候,第一次选择的是jdk(java开发工具包),第二次选择的是jre(java的运行环境)我的安装目录:【我都使用的默认目录,占用内存并不大】jdk的C:\ProgramFiles\Java\jdk1.8.0_281\jre的C:\ProgramFiles\Java\jdk1.8.0_2812.设置环境变量1)JAVA_HO…

    2022年5月19日
    34
  • 三大图表库:ECharts 、 BizCharts 和 G2,该如何选择?

    三大图表库:ECharts 、 BizCharts 和 G2,该如何选择?最近阿里正式开源的BizCharts图表库基于React技术栈,各个图表项皆采用了组件的形式,贴近React的使用特点。同时BizCharts基于G2进行封装,Bizcharts也继承了G2相关特性。公司目前统一使用的是ECharts图表库,下文将对3种图表库进行分析比对。BizCharts文档地址:BizCharts一、安装通过npm/yarn引入npminstallbizc…

    2025年6月24日
    1
  • IUnKNown接口——QueryInterface函数

    IUnKNown接口——QueryInterface函数COM笔记-QueryInterface函数fangyukuan2010.6.1客户同组件的交互都是通过一个接口完成的。在客户查询组件的其他接口时,也是通过接口完成的。这个接口就是IUnknown。它在UNKNWN.H头文件定义:如下       Interface IUnknown       {            virtual HRESULT _

    2022年6月29日
    27
  • puppeteer爬虫教程_python爬虫入门最好书籍

    puppeteer爬虫教程_python爬虫入门最好书籍译者按: 本文通过简单的例子介绍如何使用Puppeteer来爬取网页数据,特别是用谷歌开发者工具获取元素选择器值得学习。原文: AGuidetoAutomating&am

    2022年8月2日
    4
  • jasypt库的使用[通俗易懂]

    jasypt库的使用[通俗易懂]jasypt库的使用1.简介Jasypt是一个Java简易加密库,用于加密配置文件中的敏感信息,如数据库密码。jasypt库与springboot集成,在实际开发中非常方便。2.添加依赖jasypt开发者开发了starter,添加jasypt-spring-boot-starter依赖就可以了。该库中有使用到slf4j依赖,若单独测试,需添加相应依赖,或直接添加spring-boot-st…

    2022年9月26日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号