CN115048364A - 一种数据写入数据库的方法、装置、数据库服务器 - Google Patents
一种数据写入数据库的方法、装置、数据库服务器 Download PDFInfo
- Publication number
- CN115048364A CN115048364A CN202111354870.5A CN202111354870A CN115048364A CN 115048364 A CN115048364 A CN 115048364A CN 202111354870 A CN202111354870 A CN 202111354870A CN 115048364 A CN115048364 A CN 115048364A
- Authority
- CN
- China
- Prior art keywords
- log file
- threshold
- written log
- event
- pages
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/21—Design, administration or maintenance of databases
- G06F16/215—Improving data quality; Data cleansing, e.g. de-duplication, removing invalid entries or correcting typographical errors
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/245—Query processing
- G06F16/2455—Query execution
- G06F16/24552—Database cache management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/25—Integrating or interfacing systems involving database management systems
- G06F16/258—Data format conversion from or to a database
Landscapes
- Engineering & Computer Science (AREA)
- Databases & Information Systems (AREA)
- Theoretical Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computational Linguistics (AREA)
- Quality & Reliability (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本申请提供了一种数据写入数据库的方法、装置、数据库服务器,方法包括:接收来自预设函数的写入事件后,响应于写入事件,获取数据库中当前时刻的预写日志文件的页数,并对预写日志文件的页数进行阈值判断,若当前时刻的预写日志文件的页数大于或等于第一阈值,则判断在第一时间范围内,预写日志文件的页数是否增加,若预写日志文件的页数未增加,则触发检查点事件,若预写日志文件的页数增加,且预写日志文件的页数大于或等于第二阈值,则触发检查点事件,能够在减少触发检查点事件的次数同时,使得不经常在页数大于或等于第二阈值时触发检查点事件,从而避免数据库损坏。
Description
技术领域
本申请属于数据库技术领域,尤其涉及一种数据写入数据库的方法、装置、数据库服务器。
背景技术
目前,当数据库使用频率非常高时,随之而来的,日志文件页数会快速增加。在日志文件页数增加的过程中会频繁触发检查点事件,使得数据库处于频繁写入的状态,导致写入耗时过长,从而降低写入效率。
发明内容
本申请实施例提供了一种数据写入数据库的方法、装置、数据库服务器,可以解决数据写入数据库耗时长、效率低的问题。
第一方面,本申请实施例提供了一种数据写入数据库的方法,包括:
接收来自预设函数的写入事件后,响应于所述写入事件,获取数据库中当前时刻的预写日志文件的页数,并对所述预写日志文件的页数进行阈值判断;
若当前时刻的所述预写日志文件的页数大于或等于第一阈值,则判断在第一时间范围内,所述预写日志文件的页数是否增加;
若所述预写日志文件的页数未增加,则触发检查点事件;
若所述预写日志文件的页数增加,且所述预写日志文件的页数大于或等于第二阈值,则触发所述检查点事件;
其中,所述第一阈值小于所述第二阈值;
所述写入事件在应用程序检测到写入操作时产生,由所述预设函数传送。
进一步的,所述若所述预写日志文件的页数增加,且所述预写日志文件的页数大于或等于第二阈值,则触发所述检查点事件,包括:
若在第一时间范围内,所述预写日志文件的页数增加,则判断所述第一时间范围内的所述预写日志文件的页数是否大于或等于第三阈值;
若所述预写日志文件的页数大于或等于所述第三阈值,且在第二时间范围内,所述预写日志文件的页数增加,则判断所述预写日志文件的页数是否大于或等于所述第二阈值;
若所述预写日志文件的页数大于或等于所述第二阈值,则触发所述检查点事件;
所述第三阈值大于所述第一阈值且小于所述第二阈值,所述第一时间范围的时长大于所述第二时间范围的时长。
进一步的,所述方法还包括:
若所述预写日志文件的页数大于或等于所述第三阈值,且在所述第二时间范围内,所述预写日志文件的页数未增加,则触发所述检查点事件。
进一步的,所述写入事件在所述数据库的指针重定向至所述预设函数后,由所述预设函数传送。
第二方面,本申请实施例提供了一种数据写入数据库的装置,包括:
响应处理模块,用于接收来自预设函数的事件后,响应于所述写入事件,获取数据库中当前时刻的预写日志文件的页数,并对所述预写日志文件的页数进行阈值判断;
判断模块,用于若当前时刻的所述预写日志文件的页数大于或等于第一阈值,则判断在第一时间范围内,所述预写日志文件的页数是否增加;
第一触发模块,用于若所述预写日志文件的页数未增加,则触发检查点事件;
第二触发模块,用于若所述预写日志文件的页数增加,且所述预写日志文件的页数大于或等于第二阈值,则触发所述检查点事件;
其中,所述第一阈值小于所述第二阈值,所述写入事件在应用程序检测到写入操作时产生,由所述预设函数传送。
进一步的,所述第二触发模块包括:
第一判断单元,用于若在第一时间范围内,所述预写日志文件的页数增加,则判断所述第一时间范围内的所述预写日志文件的页数是否大于或等于第三阈值;
第二判断单元,用于若所述预写日志文件的页数大于或等于所述第三阈值,且在第二时间范围内,所述预写日志文件的页数增加,则判断所述预写日志文件的页数是否大于或等于所述第二阈值;
事件触发单元,用于若所述预写日志文件的页数大于或等于所述第二阈值,则触发所述检查点事件;
所述第三阈值大于所述第一阈值且小于所述第二阈值,所述第一时间范围的时长大于所述第二时间范围的时长。
进一步的,所述响应处理单元,还用于若所述预写日志文件的页数大于或等于所述第三阈值,且在所述第二时间范围内,所述预写日志文件的页数未增加,则触发所述检查点事件。
进一步的,所述写入事件在所述数据库的指针重定向至所述预设函数后,由所述预设函数传送。
第三方面,本申请实施例提供了一种数据库服务器,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如上述第一方面中任一项所述的方法。
第四方面,本申请实施例提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现如上述第一方面中任一项所述的方法。
第五方面,本申请实施例提供了一种计算机程序产品,当计算机程序产品在终端设备上运行时,使得终端设备执行上述第一方面中任一项所述的方法。
可以理解的是,上述第二方面至第五方面的有益效果可以参见上述第一方面中的相关描述,在此不再赘述。
本申请实施例与现有技术相比存在的有益效果是:
本申请实施例通过接收来自预设函数的写入事件后,响应于写入事件,获取数据库中当前时刻的预写日志文件的页数,并对预写日志文件的页数进行阈值判断,若当前时刻的预写日志文件的页数大于或等于第一阈值,则判断在第一时间范围内,预写日志文件的页数是否增加,若预写日志文件的页数未增加,则触发检查点事件,若预写日志文件的页数增加,且预写日志文件的页数大于或等于第二阈值,则触发检查点事件,实现对数据库中预写日志文件的页数多档阈值判断,在页数大于或等于第一阈值时,当页数未增加,才触发检查点事件,而当页数在增加,只在页数大于或等于第二阈值,才触发检查点事件,能够减少触发检查点事件的次数,即不用频繁进行数据同步操作,从而减少写入耗时,提高写入效率;及当页数未增加,才触发检查点事件,能够在减少触发检查点事件的次数同时,使得不经常在页数大于或等于第二阈值时触发检查点事件,从而避免数据库损坏。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本申请一实施例提供的数据写入数据库的方法的流程示意图;
图2是本申请另一实施例提供的数据写入数据库的方法的流程示意图;
图3是本申请实施例提供的数据写入数据库的装置的结构示意图;
图4是本申请实施例提供的数据库服务器的结构示意图。
具体实施方式
以下描述中,为了说明而不是为了限定,提出了诸如特定系统结构、技术之类的具体细节,以便透彻理解本申请实施例。然而,本领域的技术人员应当清楚,在没有这些具体细节的其它实施例中也可以实现本申请。在其它情况中,省略对众所周知的系统、装置、电路以及方法的详细说明,以免不必要的细节妨碍本申请的描述。
应当理解,当在本申请说明书和所附权利要求书中使用时,术语“包括”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
还应当理解,在本申请说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
如在本申请说明书和所附权利要求书中所使用的那样,术语“如果”可以依据上下文被解释为“当...时”或“一旦”或“响应于确定”或“响应于检测到”。类似地,短语“如果确定”或“如果检测到[所描述条件或事件]”可以依据上下文被解释为意指“一旦确定”或“响应于确定”或“一旦检测到[所描述条件或事件]”或“响应于检测到[所描述条件或事件]”。
另外,在本申请说明书和所附权利要求书的描述中,术语“第一”、“第二”、“第三”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
在本申请说明书中描述的参考“一个实施例”或“一些实施例”等意味着在本申请的一个或多个实施例中包括结合该实施例描述的特定特征、结构或特点。由此,在本说明书中的不同之处出现的语句“在一个实施例中”、“在一些实施例中”、“在其他一些实施例中”、“在另外一些实施例中”等不是必然都参考相同的实施例,而是意味着“一个或多个但不是所有的实施例”,除非是以其他方式另外特别强调。术语“包括”、“包含”、“具有”及它们的变形都意味着“包括但不限于”,除非是以其他方式另外特别强调。
数据库在各个行业中使用频率非常高。示例的,包括但不限于:
具备有数据库的设备与终端设备信息交互,该设备将终端设备中的联系人、通话记录进行同步,及断开连接后,清空已同步的联系人、通话记录;
或,从终端设备中批量导入或删除联系人;
或,从终端设备中批量导入或删除短信;
或,进行AndroBench测试(基准测试应用程序)。
在数据库的原生阈值判断机制中,当有数据写入时,一般通过页数达到预设页数阈值或累计的数据量达到预设存储量以此触发检查点事件。但在有些写入场景中,当写入的数据结构复杂,更加会导致预写日志文件的页数很快达到预设页数阈值,从而频繁触发检查点事件,使得数据库处于频繁写入的状态,这会阻塞后续的写入操作,并导致写入耗时过长,从而降低写入效率。
当有些设备原生的预设页数阈值小,或预设存储量小时(其一满足就触发检查点事件),这使得写入效率更低下。
示例的,在SQLite数据库的原生阈值判断机制中,当有数据写入时,一般通过页数达到100页或累计的数据量达到512K以此触发检查点事件。这会使得数据库处于频繁写入的状态,导致写入耗时过长,从而降低写入效率。
基于上述的问题,本申请实施例提供一种数据写入数据库的方法、装置、数据库服务器及可读存储介质,以此减少写入耗时,提高写入效率。
图1是本申请一实施例提供的数据写入数据库的方法的流程示意图。作为示例而非限定,可应用于异步线程的ElasticCheckpointer类中,但不以此为限。
如图1所示,所述方法包括:
S101:接收来自预设函数的写入事件后,响应于写入事件,获取数据库中当前时刻的预写日志文件的页数,并对预写日志文件的页数进行阈值判断。
其中,写入事件在应用程序检测到写入操作时产生,由预设函数传送。
示例的,阈值为多档阈值,包含第一阈值及第二阈值。其中,第一阈值小于第二阈值。
第一阈值及第二阈值可根据实际使用需求、场景、硬件配置进行设置。通常,第二阈值以累计的预写日志文件的页数是否迫切触发检查点事件来设置。示例的,第一阈值设为100,第二阈值设为1600。
S102:若当前时刻的预写日志文件的页数大于或等于第一阈值,则判断在第一时间范围内,预写日志文件的页数是否增加。
第一时间范围可据实际使用需求、场景、硬件配置进行设置。该第一时间范围可在预写日志文件的页数大于或等于第一阈值时设置,然后以第一时间范围为限,判断预写日志文件的页数是否增加,能够更好检测出预写日志文件的页数的情况。
S103:若预写日志文件的页数未增加,则触发检查点事件。
其中,预写日志文件的页数未增加,表明该次写入结束,可触发检查点事件。
S104:若预写日志文件的页数增加,且预写日志文件的页数大于或等于第二阈值,则触发检查点事件。
具体的,若预写日志文件的页数增加,表明该次写入还未结束,需判断预写日志文件的页数是否大于或等于第二阈值。当预写日志文件的页数大于或等于第二阈值,表明累计的数据量很大,此时触发检查点事件变得迫切。
本实施例通过接收来自预设函数的写入事件后,响应于写入事件,获取数据库中当前时刻的预写日志文件的页数,并对预写日志文件的页数进行阈值判断,若当前时刻的预写日志文件的页数大于或等于第一阈值,则判断在第一时间范围内,预写日志文件的页数是否增加,若预写日志文件的页数未增加,则触发检查点事件,若预写日志文件的页数增加,且预写日志文件的页数大于或等于第二阈值,则触发检查点事件,实现对数据库中预写日志文件的页数多档阈值判断,在页数大于或等于第一阈值时,当页数未增加,才触发检查点事件,而当页数在增加,只在页数大于或等于第二阈值,才触发检查点事件,能够减少触发检查点事件的次数,即不用频繁进行数据同步操作,从而减少写入耗时,提高写入效率;及当页数未增加,才触发检查点事件,能够在减少触发检查点事件的次数同时,使得不经常在页数大于或等于第二阈值时触发检查点事件,从而避免数据库损坏。
图2是本申请另一实施例提供的数据写入数据库的方法的流程示意图。组为示例而非限定,如图2所示,若预写日志文件的页数增加,且预写日志文件的页数大于或等于第二阈值,则触发检查点事件,包括:
S201:若在第一时间范围内,预写日志文件的页数增加,则判断第一时间范围内的预写日志文件的页数是否大于或等于第三阈值。
其中,第三阈值大于第一阈值且小于第二阈值,第三阈值可根据实际使用需求、场景、硬件配置进行设置。通常,第三阈值以累计的预写日志文件的页数对应的数据量是否较大来设置。示例的,第三阈值设为1000。
示例的,每当预写日志文件的页数增加,可在页数增加的时刻,新设置第一时间范围,在新设置的第一时间范围内,判断第一时间范围内的预写日志文件的页数是否大于或等于第三阈值。通过在页数增加的时刻,设置第一时间范围,能够更好判断第一时间范围内的预写日志文件的页数是否大于或等于第三阈值的同时,在页数增加后,及时判断出预写日志文件的页数是否未增加,从而及时在页数未增加时,触发检查点事件。
S202:若预写日志文件的页数大于或等于所述第三阈值,且在第二时间范围内,预写日志文件的页数增加,则判断预写日志文件的页数是否大于或等于第二阈值。
因页数是否大于或等于第三阈值,能够表明累计的数据量是否较大,达到触发检查点事件条件的时间是否更短等。若大于或等于第三阈值,则需调整判断条件。
其中,第一时间范围的时长大于第二时间范围的时长。第二时间范围可据实际使用需求、场景、硬件配置进行设置。该第二时间范围可在预写日志文件的页数大于或等于第三阈值时设置,然后以第二时间范围为限,判断预写日志文件的页数是否增加,能够更好检测出预写日志文件的页数的情况。若预写日志文件的页数增加,则判断预写日志文件的页数是否大于或等于第二阈值。
示例的,每当预写日志文件的页数增加,可在页数增加的时刻,新设置第二时间范围,在新设置的第二时间范围内,判断预写日志文件的页数是否大于或等于第二阈值。通过在页数增加的时刻,设置第二时间范围,能够更好判断预写日志文件的页数是否大于或等于第二阈值的同时,在页数增加后,及时判断出预写日志文件的页数是否未增加。
另外,若预写日志文件的页数小于所述第三阈值,则判断第一时间范围内的预写日志文件的页数是否大于或等于第三阈值。
其中,预写日志文件的页数小于所述第三阈值,表明累计的数据量不大,此时触发检查点事件不迫切,可仍以第一时间范围为限,判断第一时间范围内的预写日志文件的页数是否大于或等于第三阈值。
S203:若预写日志文件的页数大于或等于第二阈值,则触发检查点事件。
本实施例通过若在第一时间范围内,预写日志文件的页数增加,则判断第一时间范围内的预写日志文件的页数是否大于或等于第三阈值;若预写日志文件的页数大于或等于第三阈值,且在第二时间范围内,预写日志文件的页数增加,则判断预写日志文件的页数是否大于或等于第二阈值;若预写日志文件的页数大于或等于第二阈值,则触发检查点事件,基于不同的阈值,在不同的时间范围进行判断,能够及时发现预写日志文件的页数大于或等于第二阈值,从而及时触发检查点事件。
在另一实施例中,所述方法还包括:
若预写日志文件的页数大于或等于第三阈值,且在第二时间范围内,预写日志文件的页数未增加,则触发检查点事件。
在另一实施例中,写入事件在数据库的指针重定向至预设函数后,由预设函数传送。
示例的,数据库为SQLite数据库,预设函数设为WalIncNotify函数,但不以此为限。相应的,对SQLite数据库的xWallCallback指针进行重定向处理。xWallCallback指针为原生的回调函数指针,默认指向SQLite原生的阈值判断。将xWallCallback指针重定向至WalIncNotify函数,通过WalIncNotify函数传送写入事件至ElasticCheckpointer类中,能够将原生同步执行的阈值判断替换成异步执行的多档阈值判断,减少了同步执行带来的阻塞,也减少写入耗时,从而进一步提高写入效率。
应理解,上述实施例中各步骤的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本申请实施例的实施过程构成任何限定。
对应于上文实施例所述的方法,为了便于说明,仅示出了与本申请实施例相关的部分。
图3是本申请实施例提供的数据写入数据库的装置的结构示意图。作为示例而非限定,如图3所示,所述装置包括:
响应处理模块10,用于接收来自预设函数的事件后,响应于写入事件,获取数据库中当前时刻的预写日志文件的页数,并对预写日志文件的页数进行阈值判断;
判断模块11,用于若当前时刻的预写日志文件的页数大于或等于第一阈值,则判断在第一时间范围内,预写日志文件的页数是否增加;
第一触发模块12,用于若预写日志文件的页数未增加,则触发检查点事件;
第二触发模块13,用于若预写日志文件的页数增加,且预写日志文件的页数大于或等于第二阈值,则触发检查点事件;
其中,第一阈值小于第二阈值,写入事件在应用程序检测到写入操作时产生,由预设函数传送。
在另一实施例中,第二触发模块包括:
第一判断单元,用于若在第一时间范围内,预写日志文件的页数增加,则判断第一时间范围内的预写日志文件的页数是否大于或等于第三阈值;
第二判断单元,用于若预写日志文件的页数大于或等于第三阈值,且在第二时间范围内,预写日志文件的页数增加,则判断预写日志文件的页数是否大于或等于第二阈值;
事件触发单元,用于若预写日志文件的页数大于或等于第二阈值,则触发检查点事件;
第三阈值大于第一阈值且小于第二阈值,第一时间范围的时长大于第二时间范围的时长。
在另一实施例中,响应处理单元,还用于若预写日志文件的页数大于或等于第三阈值,且在第二时间范围内,预写日志文件的页数未增加,则触发检查点事件。
在另一实施例中,写入事件在数据库的指针重定向至预设函数后,由预设函数传送。
图4为本申请一实施例提供的数据库服务器的结构示意图。如图4所示,该实施例的电子设备2包括:至少一个处理器20(图4中仅示出一个)、存储器21以及存储在所述存储器21中并可在所述至少一个处理器20上运行的计算机程序22,所述处理器20执行所述计算机程序22时实现上述任意各个方法实施例中的步骤。
该电子设备2可包括,但不仅限于,处理器20、存储器21。本领域技术人员可以理解,图4仅仅是电子设备2的举例,并不构成对电子设备2的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,例如还可以包括输入输出设备、网络接入设备等。
所称处理器20可以是中央处理单元(Central Processing Unit,CPU),该处理器20还可以是其他通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
所述存储器21在一些实施例中可以是所述电子设备2的内部存储单元,例如电子设备2的硬盘或内存。所述存储器21在另一些实施例中也可以是所述电子设备2的外部存储设备,例如所述电子设备2上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(Flash Card)等。进一步地,所述存储器21还可以既包括所述电子设备2的内部存储单元也包括外部存储设备。所述存储器21用于存储操作系统、应用程序、引导装载程序(BootLoader)、数据以及其他程序等,例如所述计算机程序的程序代码等。所述存储器21还可以用于暂时地存储已经输出或者将要输出的数据。
需要说明的是,上述装置/单元之间的信息交互、执行过程等内容,由于与本申请方法实施例基于同一构思,其具体功能及带来的技术效果,具体可参见方法实施例部分,此处不再赘述。
所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,仅以上述各功能单元、模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能单元、模块完成,即将所述装置的内部结构划分成不同的功能单元或模块,以完成以上描述的全部或者部分功能。实施例中的各功能单元、模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中,上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。另外,各功能单元、模块的具体名称也只是为了便于相互区分,并不用于限制本申请的保护范围。上述系统中单元、模块的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
本申请实施例还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时可实现上述各个方法实施例中的步骤。
本申请实施例提供了一种计算机程序产品,当计算机程序产品在移动终端上运行时,使得移动终端执行时可实现上述各个方法实施例中的步骤。
所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请实现上述实施例方法中的全部或部分流程,可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。其中,所述计算机程序包括计算机程序代码,所述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读介质至少可以包括:能够将计算机程序代码携带到拍照装置/终端设备的任何实体或装置、记录介质、计算机存储器、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,RandomAccess Memory)、电载波信号、电信信号以及软件分发介质。例如U盘、移动硬盘、磁碟或者光盘等。在某些司法管辖区,根据立法和专利实践,计算机可读介质不可以是电载波信号和电信信号。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述或记载的部分,可以参见其它实施例的相关描述。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本申请的范围。
在本申请所提供的实施例中,应该理解到,所揭露的装置/网络设备和方法,可以通过其它的方式实现。例如,以上所描述的装置/网络设备实施例仅仅是示意性的,例如,所述模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通讯连接可以是通过一些接口,装置或单元的间接耦合或通讯连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
以上所述实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的精神和范围,均应包含在本申请的保护范围之内。
Claims (10)
1.一种数据写入数据库的方法,其特征在于,包括:
接收来自预设函数的写入事件后,响应于所述写入事件,获取数据库中当前时刻的预写日志文件的页数,并对所述预写日志文件的页数进行阈值判断;
若当前时刻的所述预写日志文件的页数大于或等于第一阈值,则判断在第一时间范围内,所述预写日志文件的页数是否增加;
若所述预写日志文件的页数未增加,则触发检查点事件;
若所述预写日志文件的页数增加,且所述预写日志文件的页数大于或等于第二阈值,则触发所述检查点事件;
其中,所述第一阈值小于所述第二阈值;
所述写入事件在应用程序检测到写入操作时产生,由所述预设函数传送。
2.如权利要求1所述的方法,其特征在于,所述若所述预写日志文件的页数增加,且所述预写日志文件的页数大于或等于第二阈值,则触发所述检查点事件,包括:
若在第一时间范围内,所述预写日志文件的页数增加,则判断所述第一时间范围内的所述预写日志文件的页数是否大于或等于第三阈值;
若所述预写日志文件的页数大于或等于所述第三阈值,且在第二时间范围内,所述预写日志文件的页数增加,则判断所述预写日志文件的页数是否大于或等于所述第二阈值;
若所述预写日志文件的页数大于或等于所述第二阈值,则触发所述检查点事件;
所述第三阈值大于所述第一阈值且小于所述第二阈值,所述第一时间范围的时长大于所述第二时间范围的时长。
3.如权利要求2所述的方法,其特征在于,还包括:
若所述预写日志文件的页数大于或等于所述第三阈值,且在所述第二时间范围内,所述预写日志文件的页数未增加,则触发所述检查点事件。
4.如权利要求1所述的方法,其特征在于,所述写入事件在所述数据库的指针重定向至所述预设函数后,由所述预设函数传送。
5.一种数据写入数据库的装置,其特征在于,包括:
响应处理模块,用于接收来自预设函数的事件后,响应于所述写入事件,获取数据库中当前时刻的预写日志文件的页数,并对所述预写日志文件的页数进行阈值判断;
判断模块,用于若当前时刻的所述预写日志文件的页数大于或等于第一阈值,则判断在第一时间范围内,所述预写日志文件的页数是否增加;
第一触发模块,用于若所述预写日志文件的页数未增加,则触发检查点事件;
第二触发模块,用于若所述预写日志文件的页数增加,且所述预写日志文件的页数大于或等于第二阈值,则触发所述检查点事件;
其中,所述第一阈值小于所述第二阈值,所述写入事件在应用程序检测到写入操作时产生,由所述预设函数传送。
6.如权利要求5所述的装置,其特征在于,所述第二触发模块包括:
第一判断单元,用于若在第一时间范围内,所述预写日志文件的页数增加,则判断所述第一时间范围内的所述预写日志文件的页数是否大于或等于第三阈值;
第二判断单元,用于若所述预写日志文件的页数大于或等于所述第三阈值,且在第二时间范围内,所述预写日志文件的页数增加,则判断所述预写日志文件的页数是否大于或等于所述第二阈值;
事件触发单元,用于若所述预写日志文件的页数大于或等于所述第二阈值,则触发所述检查点事件;
所述第三阈值大于所述第一阈值且小于所述第二阈值,所述第一时间范围的时长大于所述第二时间范围的时长。
7.如权利要求6所述的装置,其特征在于,所述响应处理单元,还用于若所述预写日志文件的页数大于或等于所述第三阈值,且在所述第二时间范围内,所述预写日志文件的页数未增加,则触发所述检查点事件。
8.如权利要求5所述的装置,其特征在于,所述写入事件在所述数据库的指针重定向至所述预设函数后,由所述预设函数传送。
9.一种数据库服务器,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至4任一项所述的方法。
10.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至4任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111354870.5A CN115048364A (zh) | 2021-11-16 | 2021-11-16 | 一种数据写入数据库的方法、装置、数据库服务器 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111354870.5A CN115048364A (zh) | 2021-11-16 | 2021-11-16 | 一种数据写入数据库的方法、装置、数据库服务器 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN115048364A true CN115048364A (zh) | 2022-09-13 |
Family
ID=83156662
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202111354870.5A Pending CN115048364A (zh) | 2021-11-16 | 2021-11-16 | 一种数据写入数据库的方法、装置、数据库服务器 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115048364A (zh) |
-
2021
- 2021-11-16 CN CN202111354870.5A patent/CN115048364A/zh active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109814524B (zh) | 一种车辆诊断方法、装置及系统 | |
CN109800181B (zh) | 一种基于磁盘的数据写入方法、数据写入装置及终端设备 | |
CN109766282B (zh) | 一种卡顿检测方法、卡顿检测装置及终端设备 | |
WO2020006860A1 (zh) | 一种图片缓存清理方法、装置、终端设备及介质 | |
CN113535721A (zh) | 一种数据写入方法及装置 | |
CN111414207A (zh) | 一种页面搭建方法、装置和设备 | |
CN112181830B (zh) | 内存泄露的检测方法、装置、终端及介质 | |
CN108647102B (zh) | 异构系统的服务请求处理方法、装置和电子设备 | |
CN114374392A (zh) | 一种数据压缩存储方法、装置、终端设备及可读存储介质 | |
US20220035666A1 (en) | Method and apparatus for data processing, server and storage medium | |
CN111400091B (zh) | 恢复出厂设置方法、恢复出厂设置装置及移动终端 | |
CN111694703A (zh) | 缓存区管理方法、装置和计算机设备 | |
CN111143092B (zh) | 故障录波数据处理方法、系统及终端设备 | |
CN108491315A (zh) | 页面驻留时长的统计方法、装置及计算机可读存储介质 | |
CN115048364A (zh) | 一种数据写入数据库的方法、装置、数据库服务器 | |
CN108536512B (zh) | 界面切换方法、装置及终端设备 | |
CN107526814B (zh) | 移动终端文件存储方法及装置 | |
CN112231090A (zh) | 应用进程管理方法、装置及终端设备 | |
CN110968471A (zh) | 一种程序崩溃问题上报方法、存储介质、电子设备及系统 | |
CN111679909B (zh) | 数据处理方法、装置及终端设备 | |
CN114896298A (zh) | 一种同类型标签数据预测方法、终端设备及存储介质 | |
CN113342270A (zh) | 卷卸载方法、装置和电子设备 | |
CN113051105A (zh) | 数据处理方法、装置、设备及存储介质 | |
CN109885402B (zh) | 测试函数输出数据溢出的方法、终端设备及存储介质 | |
CN117076169B (zh) | 操作系统的中断异常检测方法、装置及电子设备 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |