[发明专利]一种向数据库插入数据的方法及装置有效
申请号: | 201410160707.9 | 申请日: | 2014-04-21 |
公开(公告)号: | CN103914565B | 公开(公告)日: | 2017-05-24 |
发明(设计)人: | 周星 | 申请(专利权)人: | 北京搜狐新媒体信息技术有限公司 |
主分类号: | G06F17/30 | 分类号: | G06F17/30 |
代理公司: | 北京集佳知识产权代理有限公司11227 | 代理人: | 王宝筠 |
地址: | 100084 北京市海淀区中关*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 数据库 插入 数据 方法 装置 | ||
1.一种向数据库插入数据的方法,其特征在于,所述数据库中的每个数据表与一个计数器、一个缓冲区和一个读写锁相互对应,所述方法包括:
获取需要向所述数据库的第一数据表插入的行数据,所述行数据中的每个数据项与所述第一数据表中的每个字段一一对应,所述第一数据表与第一计数器、第一缓冲区和第一读写锁相互对应;
按照下述方式完成向数据库插入数据的操作:
使所述第一计数器累加一个计数,并将所述行数据放入所述第一缓冲区中;判断所述第一计数器中的计数值是否达到设定阈值;如果是,则使所述第一计数器中的计数值置为零,将所述第一缓冲区中缓冲的所有行数据放入所述第一数据表中,清除所述第一缓冲区中缓冲的所有行数据,继续执行所述获取需要向所述数据库的第一数据表插入的行数据的步骤;如果否,则继续执行所述获取需要向所述数据库的第一数据表插入的行数据的步骤;其中,所述第一缓冲区中的数据是来自相同或不同线程的行数据;
其中,在至少一次的所述第一读写锁的访问控制期间完成上述操作中的读写操作,所述第一读写锁的访问控制期间是从开启所述第一读写锁后到关闭所述第一读写锁前的期间。
2.根据权利要求1所述的方法,其特征在于,具体按照下述方式完成向数据库插入数据的操作:
在第一次开启所述第一读写锁的写模式后、且在第一次关闭所述第一读写锁的写模式前,使所述第一计数器累加一个计数,并将所述行数据放入所述第一缓冲区中;
判断所述第一计数器中的计数值是否达到设定阈值;
如果是,则在第二次开启所述第一读写锁的写模式后、且在第二次关闭所述第一读写锁的写模式前,使所述第一计数器中的计数值置为零;在开启所述第一读写锁的读模式后、且在关闭所述第一读写锁的读模式前,将所述第一缓冲区中缓冲的所有行数据放入所述第一数据表中;在第三次开启所述第一读写锁的写模式后、且在第三次关闭所述第一读写锁的写模式前,清除所述第一缓冲区中缓冲的所有行数据;继续执行所述获取需要向所述数据库的第一数据表插入的行数据的步骤;
如果否,则继续执行所述获取需要向所述数据库的第一数据表插入的行数据的步骤。
3.根据权利要求1或2所述的方法,其特征在于,所述第一数据表与第一预处理表相互对应,所述第一预处理表中按预设顺序存储了所述第一数据表中的每个字段,所述第一预处理表中每个字段对应的初始数据为空值;
所述获取需要向所述数据库的第一数据表插入的行数据,具体包括:
将所述行数据中的每个数据项与所述第一预处理表中的字段进行对应,并利用所述每个数据项替换所述第一预处理表中对应字段所对应的空值;
按所述预设顺序获取与所述预处理表中每个字段对应的每个数据项。
4.根据权利要求3所述的方法,其特征在于,所述第一预处理表为第一哈希表。
5.根据权利要求1或2所述的方法,其特征在于,所述第一计数器的计数值和所述第一数据表的表名存储于第二哈希表中,所述第一缓冲区中缓冲的行数据和所述第一数据表的表名存储于第三哈希表中,所述第一读写锁的数据结构和所述第一数据表的表名存储于第四哈希表中;
所述方法还包括:
根据哈希算法获取与所述第一数据表的表名对应的第一计数器、第一缓冲区和第一读写锁。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京搜狐新媒体信息技术有限公司,未经北京搜狐新媒体信息技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201410160707.9/1.html,转载请声明来源钻瓜专利网。
- 上一篇:一种二氧化碳吸收指示剂
- 下一篇:一种鉴定希瓦氏菌的表面增强拉曼散射方法
- 数据显示系统、数据中继设备、数据中继方法、数据系统、接收设备和数据读取方法
- 数据记录方法、数据记录装置、数据记录媒体、数据重播方法和数据重播装置
- 数据发送方法、数据发送系统、数据发送装置以及数据结构
- 数据显示系统、数据中继设备、数据中继方法及数据系统
- 数据嵌入装置、数据嵌入方法、数据提取装置及数据提取方法
- 数据管理装置、数据编辑装置、数据阅览装置、数据管理方法、数据编辑方法以及数据阅览方法
- 数据发送和数据接收设备、数据发送和数据接收方法
- 数据发送装置、数据接收装置、数据收发系统、数据发送方法、数据接收方法和数据收发方法
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置