内存数据操作方法及装置与流程

文档序号:13207771阅读:290来源:国知局
内存数据操作方法及装置与流程

本发明涉及数据存储技术领域,具体而言,涉及一种内存数据操作方法及装置。



背景技术:

目前对于内存数据(或微数据)的处理方式主要包括两种,第一种是将内存数据直接存储到内存中,第二种是将内存数据序列化到本地文件中。这两种方式都存在一定弊端,第一种方式虽然便于操作内存数据,但程序一旦重启或设备宕机内存数据就会丢失,无法持久化地将内存数据保存下来。第二种方式相对第一种可以持久化地保存内存数据,但不便于数据操作。



技术实现要素:

有鉴于此,本发明的目的在于提供一种内存数据操作方法及装置,以改善上述问题。

为了达到上述目的,本发明实施例提供一种内存数据操作方法,所述方法包括:

建立内存数据库的数据库文件,并建立所述内存数据库与应用程序之间的连接;

将所述数据库文件与预先建立的数据库工具类封装成类库;

响应第一操作请求,在应用程序中加载所述类库,使用所述数据库文件存储该应用程序内存数据;

响应第二操作请求,调用所述数据库工具类,对所述数据库文件中的内存数据执行与所述第二操作请求对应的操作。

可选地,在上述方法中,建立所述内存数据库与应用程序之间的连接的步骤,包括:

注册用于建立数据库连接的驱动程序;

加载所述驱动程序,并基于所述驱动程序建立所述内存数据库与应用程序之间的连接。

可选地,在上述方法中,所述内存数据库为sqlite数据库。

可选地,在上述方法中,所述驱动程序为org.sqlite.jdbc。

可选地,在上述方法中,所述内存数据库文件通过cmd指令建立或通过sqlite可视化管理工具建立。

可选地,在上述方法中,所述数据库工具类包括数据增加指令、数据删除指令、数据改写指令以及数据查询指令。

本发明实施例还提供一种内存数据操作装置,所述装置包括:

建立模块,用于建立内存数据库的数据库文件,并建立所述内存数据库与应用程序之间的连接;

封装模块,用于将所述数据库文件与预先建立的数据库工具类封装成类库;

第一操作模块,用于响应第一操作请求,在应用程序中加载所述类库,使用所述内存数据库存储该应用程序的内存数据;

第二操作模块,用于响应第二操作请求,调用所述数据库工具类,对所述数据库文件中的内存数据执行与所述第二操作请求对应的操作。

可选地,在上述装置中,所述建立模块建立所述内存数据库与应用程序之间的连接的方式,包括:

注册用于建立数据库连接的驱动程序;

加载所述驱动程序,并基于所述驱动程序建立所述内存数据库文件与应用程序之间的连接。

可选地,在上述装置中,所述内存数据库为sqlite数据库。

可选地,在上述装置中,所述驱动程序为org.sqlite.jdbc。

本发明实施例提供的内存数据操作方法及装置,通过内存数据库来存储应用程序的内存数据,并基于该内存数据库建立了用于操作内存数据的接口,便于通过该接口操作该内存数据库中存储的内存数据。如此,既能够持久化地存储内存数据,又提高了内存数据的操作效率。

为使本发明的上述目的、特征和优点能更明显易懂,下文特举较佳实施例,并配合所附附图作详细说明。

附图说明

为了更清楚地说明本发明实施例的方案,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。

图1为本发明实施例提供的一种电子设备的方框示意图。

图2为本发明实施例提供的一种内存数据操作方法的流程示意图。

图3为图2所示步骤s110的子步骤示意图。

图4为本发明实施例提供的一种内存数据操作装置的功能模块框图。

图标:100-电子设备;110-内存数据操作装置;111-建立模块;112-封装模块;113-第一操作模块;114-第二操作模块;120-存储器;130-处理器。

具体实施方式

下面将结合本发明实施例中附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。通常在此处附图中描述和展示的本发明实施例的组件可以以各种不同的配置来布置和设计。

因此,以下对在附图中提供的本发明的实施例的详细描述并非旨在限制要求保护的本发明的范围,而是仅仅表示本发明的选定实施例。基于本发明的实施例,本领域技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。

应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。同时,在本发明的描述中,术语“第一”、“第二”等仅用于区分描述,而不能理解为指示或暗示相对重要性。

如图1所示,是本发明实施例提供的一种电子设备100的方框示意图,所述电子设备100中安装有应用程序,本发明实施例提供的内存数据操作方法及装置可以应用于所述应用程序。所述电子设备100包括内存数据操作装置110、存储器120以及处理器130。

其中,所述存储器120及处理器130各元件相互之间直接或间接地电性连接,以实现数据的传输或交互。例如,这些元件相互之间可通过一条或多条通讯总线或信号线实现电性连接。内存数据操作装置110包括至少一个可以软件或固件(firmware)的形式存储于存储器120中或固化在电子设备100的操作系统(operatingsystem,os)中的软件功能模块。

所述处理器130用于执行存储在存储器120中的可执行模块,例如内存数据操作装置110所包括的软件功能模块及计算机程序等。

在本实施例中,所述存储器120可以是,但不限于,随机存取存储器(randomaccessmemory,ram),只读存储器(readonlymemory,rom),可编程只读存储器(programmableread-onlymemory,prom),可擦除只读存储器(erasableprogrammableread-onlymemory,eprom),电可擦除只读存储器(electricerasableprogrammableread-onlymemory,eeprom)等。

所述处理器130可以是一种集成电路芯片,具有信号处理的能力。所述处理器130也可以是通用处理器,例如,中央处理器(centralprocessingunit,cpu)、网络处理器(networkprocessor,np)等;还可以是数字信号处理器(dsp))、专用集成电路(asic)、现场可编程门阵列(fpga)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。所述处理器130可以实现或者执行本发明实施例中的公开的各方法、步骤及逻辑框图。上述通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。

应当理解,图1所示的结构仅为示意,电子设备100可以具有比图1所示更多或更少的组件,也可以具有与图1所示不同的配置。需要说明的是,图1所示的各组件可以软件、硬件或其组合实现。

如图2所示,是本发明实施例提供的一种内存数据操作方法的流程示意图,所述内存数据操作方法可应用于图1所示的电子设备100中的应用程序,用于对电子设备100中应用程序的内存数据进行存储和操作。在本实施例中,电子设备100可以是基于java的电子设备,电子设备100中的应用程序可以是java程序。

下面将对图2所示的具体流程及步骤进行详细阐述。

步骤s110,建立内存数据库的数据库文件,并建立所述内存数据库与应用程序之间的连接。

在本实施例中,所述内存数据库可以是sqlite数据库,sqlite数据库是一种轻型的关系型数据库。就sqlite数据库而言,一个数据库文件即为一个数据库,操作数据库实际上是对该数据库文件的操作。

因而,建立内存数据库与应用程序之间的连接,也可称为建立数据库连接,其本质是建立内存数据库与应用程序之间的数据传输通道,以便在应用程序需要操作内存数据库中的数据时开启该数据传输通道。应当理解,本实施例中建立的数据库连接并非是内存数据库与某一个具体应用程序的连接,而是一个可以用于操作该内存数据库的连接对象(connection)。

在本实施例中,当内存数据库为sqlite时,建立内存数据库与应用程序之间的连接,即为建立sqlite数据库与应用程序之间的连接。

可选地,在本实施例中,所述数据库文件可以通过cmd命令行建立,也可以通过sqlite数据库可视化管理工具建立。

可选地,在本实施例中,步骤s110中建立所述内存数据库与应用程序之间的连接的步骤可以通过步骤s111和步骤s112两个子步骤实现。

步骤s111,注册用于建立数据库连接的驱动程序。

在本实施例中,所述驱动程序可以是org.sqlite.jdbc。需要说明的是,jdbc(javadatabaseconnectivity,java数据库连接)是一种用于执行sql语句的javaapi(applicationprogramminginterface,应用程序编程接口)。在实际应用中,jdbc通过jdbc驱动程序规范完整地实现,通过jdbc驱动程序可以建立java程序与数据库之间的通信渠道(也即,数据库连接)。

在使用jdbc驱动程序建立数据库连接之前,需要在驱动管理器中注册需要使用的驱动程序。在本实施例中,被注册的驱动程序即为org.sqlite.jdbc。

步骤s112,加载所述驱动程序,并基于所述驱动程序建立所述内存数据库与应用程序之间的连接。

在本实施例中,假设步骤s110中建立的数据库文件为test.db,则步骤s111和步骤s112可以通过如下代码实现:

stringdbfilepath="test.db";

class.forname("org.sqlite.jdbc");

connect=drivermanager.getconnection("jdbc.sqlite;"+dbfilepath)。

其中,class.forname("org.sqlite.jdbc")用于告知电子设备100数据库文件test.db需要使用的驱动程序。工具类sql.drivermanager用于处理jdbc驱动程序的加载和卸载。工具类sql.connection用于建立java程序与内存数据库之间的连接。

进一步地,drivermanager.getconnection()的输入参数可以包括数据库地址(如url地址)、用户名及密码。该数据库地址与所选的数据库驱动相对应,不同的数据库驱动具有不同的地址。该密码可根据用户需求进行灵活设置,如此,可以提高内存数据存储的安全性。

步骤s120,将所述数据库文件与预先建立的数据库工具类封装成类库。

在本实施例中,所述数据库工具类中可以包括数据增加指令、数据删除指令、数据改写指令以及数据查询指令,用于对内存数据库中的内存数据进行增加、删除、改写或查询。实施时,可以预先编写好上述指令,并将编写好的指令封装成一工具类(utils),也即,所述数据库工具类。

在本实施例中,是将所述数据库文件与所述数据库工具类一并封装成类库(jar包)。

步骤s130,响应第一操作请求,在应用程序中加载所述类库,使用所述内存数据库存储该应用程序的内存数据。

实施时,在需要使用内存数据库来存储内存数据时即可在相应的应用程序中加载该jar包。其中,第一操作请求是指需要使用内存数据库的操作请求。

步骤s140,响应第二操作请求,调用所述数据库工具类,对所述内存数据库中的内存数据执行与所述第二操作请求对应的操作。

在本实施例中,若需要对内存数据库进行操作,例如,需要增、删、查或改所述内存数据库中的内存数据时,即可调用所述数据库工具类,并通过所述数据库工具类中对应的指令执行与所述第二操作请求对应的操作。

其中,所述第二操作请求是指sql语句,该sql语句中用于请求增加内存数据、删除内存数据、更改内存数据以及查询内存数据中的至少一个。实施时,若该sql语句中用于请求增加内存数据,则调用所述数据库工具类中的数据增加指令。若该sql语句用于请求删除内存数据,则调用所述数据工具类中的数据删除指令。如此,可以极大地提高数据操作效率。

如图4所示,本发明实施例还提供一种内存数据操作装置110。所述内存数据操作装置110包括建立模块111、封装模块112、第一操作模块113以及第二操作模块114。

其中,所述建立模块111用于建立内存数据库的数据文件,并建立所述内存数据与应用程序之间的连接。

在本实施例中,关于所述建立模块111的描述具体可参考对图2所示步骤s110的详细描述。也即,所述步骤s110可以由所述建立模块111执行。

可选地,在本实施例中,所述建立模块111可以通过如下方式建立所述数据库文件与所述内存数据库之间的连接:

注册用于建立数据库连接的驱动程序,加载所述驱动程序,并基于所述驱动程序建立所述内存数据库与应用程序之间的连接。

可选地,在本实施例中,所述内存数据库可以是sqlite数据库。

可选地,在本实施例中,所述驱动程序可以是org.sqlite.jdbc。

所述封装模块112用于将所述数据库文件与预先建立的数据库工具类封装成类库。

在本实施例中,关于所述封装模块112的描述具体可参考对图2所示步骤s120的详细描述,也即,所述步骤s120可以由所述封装模块112执行。

所述第一操作模块113用于响应第一操作请求,在应用程序中加载所述类库,使用所述内存数据库存储所述应用程序的内存数据。

在本实施例中,关于所述第一操作模块113的描述具体可参考对图2所示步骤s130的详细描述,也即,所述步骤s130可以由所述第一操作模块113执行。

所述第二操作模块114用于响应第二操作请求,调用所述数据库工具类,对所述数据库文件中的内存数据执行与所述第二操作请求对应的操作。

在本实施例中,关于所述第二操作模块114的描述具体可参考度图2所示步骤s140的详细描述,也即步骤s140可以由所述第二操作模块114执行。

综上所述,本发明实施例提供的内存数据操作方法及装置,通过内存数据库来存储应用程序的内存数据,并基于该内存数据库建立了用于操作内存数据的接口,便于通过该接口操作该内存数据库中存储的内存数据。如此,既能够持久化地存储内存数据,又提高了内存数据的操作效率。

在本申请所提供的几个实施例中,应该理解到,所揭露的装置和方法,也可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,附图中的流程图和框图显示了根据本发明的多个实施例的装置、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段或代码的一部分,所述模块、程序段或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现方式中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或动作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。

另外,在本发明各个实施例中的各功能模块可以集成在一起形成一个独立的部分,也可以是各个模块单独存在,也可以两个或两个以上模块集成形成一个独立的部分。

所述功能如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:u盘、移动硬盘、只读存储器(rom,read-onlymemory)、随机存取存储器(ram,randomaccessmemory)、磁碟或者光盘等各种可以存储程序代码的介质。

需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。

以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应所述以权利要求的保护范围为准。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1