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

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • python向量叉乘_矢量的点乘和叉乘公式

    python向量叉乘_矢量的点乘和叉乘公式向量的内积(点乘)定义概括地说,向量的内积(点乘/数量积)。对两个向量执行点乘运算,就是对这两个向量对应位一一相乘之后求和的操作,如下所示,对于向量a和向量b:a和b的点积公式为:这里要求一维向量a和向量b的行列数相同。注意:点乘的结果是一个标量(数量而不是向量)定义:两个向量a与b的内积为a·b=|a||b|cos∠(a,b),特别地,0·a=a·0=0;若a,b是非零向量,则a…

  • xx学OD — 函数参考

    xx学OD — 函数参考

  • SQL Server数据仓库的基础架构规划

    SQL Server数据仓库的基础架构规划

    2021年11月27日
  • 最小二乘法的详细推导过程-比之前见过的推导都简单!!!

    最小二乘法的详细推导过程-比之前见过的推导都简单!!!最小二乘法发展于天文学和大地测量学领域,科学家和数学家尝试为大航海探索时期的海洋航行挑战提供解决方案。准确描述天体的行为是船舰在大海洋上航行的关键,水手不能再依靠陆上目标导航作航行。来源:我是码农,转载请保留出处和链接!本文链接:http://www.54manong.com/?id=1203(function(){vars=”_”+Ma…

  • ThinkPHP5旅游管理系统

    ThinkPHP5旅游管理系统Q1115487855ThinkPHP5旅游管理系统一系统介绍本旅游管理系统基于ThinkPHP5开发,系统角色分为用户和管理员两种,系统分为前后台,用户可在前台注册登录、发布行程单和游记等,管理员登录后台进行管理。技术栈ThinkPHP5+mysql+bootstrap+jquery+vscode+phpstudy二系统功能用户1注册/登录/注销2个人中心

  • WinForm和WPF的区别「建议收藏」

    一、控件的差异作为Windows桌面UI开发的两大.net开发库,WinForm和WPF同时存在着。之所以功能如此重合的两个库同时存在,是因为两者的底层差异非常大,WinForm底层依赖于传统的Win32API,特别是User32.dll;而WPF则底层依赖于Direct3D。而我们知道User32和Direct3D两者是平行存在,彼此独立的。WPF之前几乎所有的WindowsUI开发都依赖于User32,当然游戏除外。随着Direct3D的日趋成熟和显卡的普通性能提升,微软力图改变这种状况,所以开发

发表回复

您的电子邮箱地址不会被公开。

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