CN112307021A - 数据处理方法、装置、设备和存储介质 - Google Patents

数据处理方法、装置、设备和存储介质 Download PDF

Info

Publication number
CN112307021A
CN112307021A CN202011149943.2A CN202011149943A CN112307021A CN 112307021 A CN112307021 A CN 112307021A CN 202011149943 A CN202011149943 A CN 202011149943A CN 112307021 A CN112307021 A CN 112307021A
Authority
CN
China
Prior art keywords
data
type field
data stream
binary data
graph
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
Application number
CN202011149943.2A
Other languages
English (en)
Inventor
朱飞飞
谢永恒
万月亮
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing Ruian Technology Co Ltd
Original Assignee
Beijing Ruian Technology Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Beijing Ruian Technology Co Ltd filed Critical Beijing Ruian Technology Co Ltd
Priority to CN202011149943.2A priority Critical patent/CN112307021A/zh
Publication of CN112307021A publication Critical patent/CN112307021A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/22Indexing; Data structures therefor; Storage structures
    • G06F16/2282Tablespace storage structures; Management thereof
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/24Querying
    • G06F16/242Query formulation
    • G06F16/2433Query languages
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/28Databases characterised by their database models, e.g. relational or object models
    • G06F16/284Relational databases

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Physics & Mathematics (AREA)
  • Data Mining & Analysis (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Mathematical Physics (AREA)
  • Computational Linguistics (AREA)
  • Software Systems (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明实施例公开了一种数据处理方法、装置、设备和存储介质,该方法包括:在Oracle数据库中创建表,并在表中设置BLOB类型字段;获取图文件,并将图文件转换成二进制数据流;将二进制数据流写入该BLOB类型字段。即本发明实施例,采用BLOB类型字段在Oracle数据库中存储数据,由于BLOB类型字段是二进制大对象,使用二进制流保存数据,而图数据通常是以二进制类型保存的,因而,本发明实施例为图数据在Oracle数据库中存储提供了有效的解决方案。

Description

数据处理方法、装置、设备和存储介质
技术领域
本发明涉及数据处理技术,尤其涉及一种数据处理方法、装置、设备和存储介质。
背景技术
Oracle数据库,是目前世界上使用最为广泛的数据库管理***,作为一个通用的数据库***,它具有完整的数据管理功能;作为一个关系型数据库,它是一个完备关系的产品;作为分布式数据库,它实现了分布式处理功能。Oracle数据库具有***可移植性好、使用方便、功能强等优点,适用于各类大、中、小、微机环境。Oracle数据库是一种高效率、可靠性好的、适应高吞吐量的数据库方案。
目前,Oracle数据库中通常采用CLOB类型字段来存储数据,CLOB类型字段使用字符(char)来保存数据,因而,CLOB类型字段比较适于文本、文档类数据的存储,而对于图数据,目前尚无好的存储方案。
发明内容
本发明实施例提供一种数据处理方法、装置、设备和存储介质,方便了图数据的存储。
第一方面,本发明实施例提供一种数据处理方法,所述方法包括:
在Oracle数据库中创建表,并在所述表中设置BLOB类型字段;
获取图文件,并将所述图文件转换成二进制数据流;
将所述二进制数据流写入所述BLOB类型字段。
可选地,在Oracle数据库中创建表,并在所述表中设置BLOB类型字段之后,还包括:
创建用户,并将所述表授权给所述用户。
可选地,所述获取图文件,包括:
接收所述用户发起的写数据请求;
根据所述写数据请求获取所述图文件。
可选地,所述图文件有多个,所述将所述图文件转换成二进制数据流,包括:
按照批处理数量阈值对所述图文件分组;
按照所述分组将所述图文件转换成二进制数据流。
可选地,所述将所述二进制数据流写入所述BLOB类型字段,包括:
构建SQL写数据语句;
将所述二进制数据流作为写参数写入所述SQL写数据语句;
执行所述SQL写数据语句,以将所述二进制数据流写入所述BLOB类型字段。
可选地,在将所述二进制数据流写入所述BLOB类型字段之后,还包括:
接收所述用户发起的读数据请求;
根据所述读数据请求从所述BLOB类型字段读取所述二进制数据流;
将所述二进制数据流转换成所述图文件。
可选地,所述根据所述读数据请求从所述BLOB类型字段读取所述二进制数据流,包括:
构建SQL读数据语句;
从所述读数据请求获取读参数,并将所述读参数写入所述SQL读数据语句;
执行所述SQL读数据语句,以从所述BLOB类型字段读取所述二进制数据流。
第二方面,本发明实施例提供一种数据处理装置,所述装置包括:
设置模块,用于在Oracle数据库中创建表,并在所述表中设置BLOB类型字段;
获取模块,用于获取图文件;
第一转换模块,用于将所述图文件转换成二进制数据流;
写数据模块,用于将所述二进制数据流写入所述BLOB类型字段。
可选地,所述装置还包括:
授权模块,用于创建用户,并将所述表授权给所述用户。
可选地,所述获取模块包括:
接收子模块,用于接收所述用户发起的写数据请求;
获取子模块,用于根据所述写数据请求获取所述图文件。
可选地,所述图文件有多个,所述第一转换模块包括:
分组子模块,用于按照批处理数量阈值对所述图文件分组;
转换子模块,用于按照所述分组将所述图文件转换成二进制数据流。
可选地,所述写数据模块包括:
第一构建子模块,用于构建SQL写数据语句;
第一写入子模块,用于将所述二进制数据流作为写参数写入所述SQL写数据语句;
第一执行子模块,用于执行所述SQL写数据语句,以将所述二进制数据流写入所述BLOB类型字段。
可选地,所述装置还包括:
接收模块,用于接收所述用户发起的读数据请求;
读数据模块,用于根据所述读数据请求从所述BLOB类型字段读取所述二进制数据流;
第二转换模块,用于将所述二进制数据流转换成所述图文件。
可选地,所述读数据模块包括:
第二构建子模块,用于构建SQL读数据语句;
第二写入子模块,用于从所述读数据请求获取读参数,并将所述读参数写入所述SQL读数据语句;
第二执行子模块,用于执行所述SQL读数据语句,以从所述BLOB类型字段读取所述二进制数据流。
第三方面,本发明实施例还提供了一种电子设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现如本发明实施例中任一所述的数据处理方法。
第四方面,本发明实施例还提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如本发明实施例中任一所述的数据处理方法。
本发明实施例中,会在Oracle数据库中创建表,并在表中设置BLOB类型字段,然后获取图文件,并将图文件转换成二进制数据流,最后将二进制数据流写入该BLOB类型字段,即本发明实施例,采用BLOB类型字段在Oracle数据库中存储数据,由于BLOB类型字段是二进制大对象,使用二进制流保存数据,而图数据通常是以二进制类型保存的,因而,本发明实施例为图数据的存储提供了有效的解决方案。
附图说明
图1是本发明实施例提供的数据处理方法的一个应用场景图。
图2是本发明实施例提供的数据处理方法的一个流程示意图。
图3是本发明实施例提供的数据处理方法的另一流程示意图。
图4是本发明实施例提供的数据处理方法的又一流程示意图。
图5是本发明实施例提供的数据处理装置的一个结构示意图。
图6是本发明实施例提供的数据处理装置的另一结构示意图。
图7是本发明实施例提供的电子设备的一个结构示意图。
具体实施方式
下面结合附图和实施例对本发明作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释本发明,而非对本发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与本发明相关的部分而非全部结构。
本发明实施例提供一种数据处理方法、装置、设备和存储介质。请参阅图1,图1是本发明实施例数据处理方法的一个应用场景图,该应用场景中可以包括数据处理装置,该数据处理装置可采用软件和/或硬件的方式实现,该数据处理装置具体可以集成在平板电脑、笔记本电脑、台式电脑等具备储存单元并安装有微处理器而具有运算能力的电子设备中。以该数据处理装置集成在电子设备中为例,如图1所示,该电子设备可以在Oracle数据库中创建表,并在表中设置BLOB类型字段,然后获取图文件,并将图文件转换成二进制数据流,将二进制数据流写入该BLOB类型字段,从而实现将图数据存入Oracle数据库;进一步地,电子设备还可以从BLOB类型字段读出该二进制数据流,并将二进制数据流转换成图文件,从而实现从Oracle数据库读出图数据。
此外,该应用场景中还可以包括服务器,服务器可以为Oracle数据库所在的后台服务器,主要用于根据电子设备的请求将图数据存入Oracle数据库,以及从Oracle数据库读出图数据。
本发明实施例中,采用BLOB类型字段在Oracle数据库中存储数据,由于BLOB类型字段是二进制大对象,使用二进制流保存数据,而图数据通常是以二进制类型保存的,因而,本发明实施例为图数据的存储提供了有效的解决方案。
需要说明的是,图1所示的场景图仅仅是一个示例,该场景是为了更加清楚的说明本发明实施例的技术方案,并不构成对于本发明实施例提供的技术方案的限定,本领域普通技术人员可知,随着电子设备的演变和新业务场景的出现,本发明实施例提供的技术方案对于类似的技术问题,同样适用。
图2为本发明实施例提供的数据处理方法的一个流程示意图,该方法可以由本发明实施例提供的数据处理装置来执行,该装置可采用软件和/或硬件的方式实现,该装置可以为电子设备。参考图2,该方法具体可以包括如下步骤:
步骤201,在Oracle数据库中创建表,并在表中设置BLOB类型字段。
由于数据库的每一次访问,都需要一个数据库连接,而建立数据库连接非常消耗时间和资源,为了便于后续与Oracle数据库进行交互,提高数据处理效率,可以在Oracle数据库所在的服务器启动时,创建预设数量的连接以建立连接池,这样后续在与Oracle数据库进行数据交互时,可以直接利用连接池中的空闲连接与Oracle数据库进行交互。具体创建连接池的方法可以包括:
(1)在数据源(DataSource)构造函数中批量创建与数据库的连接,并把创建的连接加入链表(LinkedList)对象中;
(2)设置获取连接(getConnection)方法,让获取连接方法每次调用时,从链表中取一个连接返回给用户;
(3)当用户使用完连接,调用连接关闭(Connection.close)方法时,设置连接对象将自己返回到链表中,而不要把连接还给数据库。
当需要在Oracle数据库中创建表时,可以从连接池中调用一个空闲的连接,利用该空闲的连接在Oracle数据库中创建表。
示例地,可以通过SQL表创建语句在Oracle数据库中创建表。比如,可以用组件库ADO.NET构建SQL表创建语句,并在SQL表创建语句中写入表名称、列名称、每列对应的数据类型、每列最大长度值等参数,最后通过执行该SQL表创建语句即可实现在Oracle数据库中创建表。当然,还可以通过其他方式在Oracle数据库中创建表,比如,可以通过引用组件库SMO库并调用SMO函数,从而在Oracle数据库中创建表,此处不做具体限定。
在创建表之后,可以在所创建的表中设置BLOB类型字段,BLOB是一个二进制大对象,可以用来存储可变数量的数据,BLOB中存储的通常是二进制数据。BLOB可以分为四种:TinyBlob、Blob、MediumBlob、LongBlob,这几个类型之间的主要区别是在存储文件的最大大小上不同,具体可如下表1所示,本发明实施例中,可以根据实际的图数据存储需求选取相应类型的BLOB。
类型 文件大小上限
TinyBlob 255B
Blob 65K
MediumBlob 16M
LongBlob 4G
表1
在一个具体的实施例中,为保证表中的数据安全,还可以将表进行用户授权,即在创建表,并在表中设置BLOB类型字段之后,还可以包括以下步骤:
创建用户,并将表授权给用户。
具体地,可以根据用户输入的用户名、密码等信息创建用户,创建用户之后,可以为用户分配表,并将表的操作权限授权给用户,表的操作权限包括但不限于:表数据的查询、***、更新、删除等。
步骤202,获取图文件,并将图文件转换成二进制数据流。
具体实现中,比如,可以从电子设备本地获取图文件,然后使用fopen函数读取图文件的图片信息,使用“fread($fp,filesize($img))”方法将图文件转换成二进制数据流。
具体地,如果将表授权给用户了,在获取图文件时,可以接收用户发起的写数据请求,根据该写数据请求获取图文件。比如,表的授权用户为用户A,则用户A需要将本地存储的图片X存入Oracle数据库时,可以发起写数据请求,电子设备根据用户的写数据请求从本地获取图片A,并将图片A转换成二进制数据流。
在一个具体的实施例中,如果需要写入Oracle数据库的图文件有多个,则可以进行批量写入,以提高写入效率。即当图文件有多个时,将图文件转换成二进制数据流可以包括以下步骤:
按照批处理数量阈值对图文件分组;
按照分组将图文件转换成二进制数据流。
批处理数量阈值可以根据实际情况预先设置,比如可以设置为10个、20个等。即当图文件有多个时,可以对这多个图文件分组,一组图文件同时进行二进制转换并写入。
步骤203,将二进制数据流写入BLOB类型字段。
由于BLOB自身有游标(cursor),必须使用BLOB自身的游标对BLOB进行操作,因而在将二进制数据流写入BLOB之前,可以先获取BLOB自身的游标,具体地,可以先在表中***一个空的BLOB,以创建这个BLOB的游标,然后再把这个空的BLOB的游标用查询(select)语句查询出来,最后利用该BLOB的游标将二进制数据流写入BLOB类型字段。
具体地,可以利用SQL写数据语句将二进制数据流写入BLOB类型字段,具体方法包括:
(1)构建SQL写数据语句;SQL写数据语句,比如setBinaryStream。
(2)将二进制数据流作为写参数写入SQL写数据语句;
(3)执行SQL写数据语句,以将二进制数据流写入BLOB类型字段。
本发明实施例中,会在Oracle数据库中创建表,并在表中设置BLOB类型字段,然后获取图文件,并将图文件转换成二进制数据流,最后将二进制数据流写入该BLOB类型字段,即本发明实施例,采用BLOB类型字段在Oracle数据库中存储数据,由于BLOB类型字段是二进制大对象,使用二进制流保存数据,而图数据通常是以二进制类型保存的,因而,本发明实施例为图数据在Oracle数据库中存储提供了有效的解决方案。
上述实施例所描述的方法,下面实施例将举例作进一步详细说明。请参阅图3,图3是本发明实施例提供的数据处理方法的另一流程示意图,本实施例将以图数据写入Oracle数据库为例,本实施例的方法具体可以包括如下步骤:
步骤301,在Oracle数据库中创建表,并在表中设置BLOB类型字段。
示例地,可以通过SQL表创建语句在Oracle数据库中创建表;比如,可以用组件库ADO.NET构建SQL表创建语句,并在SQL表创建语句中写入表名称、列名称、每列对应的数据类型、每列最大长度值等参数,最后通过执行该SQL表创建语句即可实现在Oracle数据库中创建表。
步骤302,创建用户,并将表授权给用户。
具体地,可以根据用户输入的用户名、密码等信息创建用户,创建用户之后,可以为用户分配表,并将表的操作权限授权给用户,表的操作权限包括但不限于:表数据的查询、***、更新、删除等。
步骤303,接收用户发起的写数据请求。
比如,当用户需要将图文件存入Oracle数据库时,可以发起写数据请求,电子设备接收用户发起的写数据请求。
步骤304,根据写数据请求获取图文件。
步骤305,将图文件转换成二进制数据流。
比如,可以使用fopen函数读取图文件的图片信息,使用“fread($fp,filesize($img))”方法将图文件转换成二进制数据流。
步骤306,构建SQL写数据语句。
SQL写数据语句,比如setBinaryStream。
步骤307,将二进制数据流作为写参数写入SQL写数据语句。
步骤308,执行SQL写数据语句,以将二进制数据流写入BLOB类型字段。
上述方案,通过在Oracle数据库的表中设置BLOB类型字段,采用BLOB类型字段在Oracle数据库中存储数据,由于BLOB类型字段是二进制大对象,使用二进制流保存数据,而图数据通常是以二进制类型保存的,因而,方便了图数据的存储。
请参阅图4,图4是本发明实施例提供的数据处理方法的又一流程示意图,本实施例将以从Oracle数据库读出图数据为例,本实施例的方法具体可以包括如下步骤:
步骤401,接收用户发起的读数据请求。
比如,当用户需要从Oracle数据库中读取某个图文件时,可以发起读数据请求,电子设备接收用户发起的读数据请求。
步骤402,构建SQL读数据语句。
SQL读数据语句,比如getBrinaryStream。
步骤403,从读数据请求获取读参数,并将读参数写入SQL读数据语句。
读参数,比如数据名称、类型等。
步骤404,执行SQL读数据语句,以从BLOB类型字段读取二进制数据流。
步骤405,将二进制数据流转换成图文件。
具体地,可以获取用户设置的文件存储路径,在将二进制数据流转换成图文件之后,可以根据该文件存储路径存储该图文件。
上述方案,通过构建的SQL读数据语句,从Oracle数据库中读取BLOB类型字段存储的二进制数据流,将该二进制数据流进行转换即可得到图文件,方便了从Oracle数据库读出图数据。
此外,还可以通过构建其他类型的SQL语句,实现对Oracle数据库中BLOB类型字段存储的数据进行修改、删除等其他操作,此处不再赘述。
图5是本发明是实施例提供的数据处理装置的一个结构示意图,该装置适用于执行本发明实施例提供的数据处理方法。如图5所示,该装置具体可以包括:
设置模块501,用于在Oracle数据库中创建表,并在所述表中设置BLOB类型字段;
获取模块502,用于获取图文件;
第一转换模块503,用于将所述图文件转换成二进制数据流;
写数据模块504,用于将所述二进制数据流写入所述BLOB类型字段。
一实施例中,如图6所示,所述装置还包括:
授权模块505,用于创建用户,并将所述表授权给所述用户。
一实施例中,如图6所示,所述获取模块502包括:
接收子模块5021,用于接收所述用户发起的写数据请求;
获取子模块5022,用于根据所述写数据请求获取所述图文件。
一实施例中,所述图文件有多个,如图6所示,所述第一转换模块503包括:
分组子模块5031,用于按照批处理数量阈值对所述图文件分组;
转换子模块5032,用于按照所述分组将所述图文件转换成二进制数据流。
一实施例中,如图6所示,所述写数据模块504包括:
第一构建子模块5041,用于构建SQL写数据语句;
第一写入子模块5042,用于将所述二进制数据流作为写参数写入所述SQL写数据语句;
第一执行子模块5043,用于执行所述SQL写数据语句,以将所述二进制数据流写入所述BLOB类型字段。
一实施例中,如图6所示,所述装置还包括:
接收模块506,用于接收所述用户发起的读数据请求;
读数据模块507,用于根据所述读数据请求从所述BLOB类型字段读取所述二进制数据流;
第二转换模块508,用于将所述二进制数据流转换成所述图文件。
一实施例中,如图6所示,所述读数据模块507包括:
第二构建子模块5071,用于构建SQL读数据语句;
第二写入子模块5072,用于从所述读数据请求获取读参数,并将所述读参数写入所述SQL读数据语句;
第二执行子模块5073,用于执行所述SQL读数据语句,以从所述BLOB类型字段读取所述二进制数据流。
本领域的技术人员可以清楚地了解到,为描述的方便和简洁,仅以上述各功能模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成,即将装置的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。上述描述功能模块的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
本发明实施例的装置,会在Oracle数据库中创建表,并在表中设置BLOB类型字段,然后获取图文件,并将图文件转换成二进制数据流,最后将二进制数据流写入该BLOB类型字段,即本发明实施例的装置,采用BLOB类型字段在Oracle数据库中存储数据,由于BLOB类型字段是二进制大对象,使用二进制流保存数据,而图数据通常是以二进制类型保存的,因而,本发明实施例为图数据的存储提供了有效的解决方案。
图7为本发明实施例提供的一种电子设备的结构图。图7示出了适于用来实现本发明实施方式的示例性电子设备12的框图。图7显示的电子设备12仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图7所示,电子设备12以通用计算设备的形式表现。电子设备12的组件可以包括但不限于:一个或者多个处理器或者处理单元16,***存储器28,连接不同***组件(包括***存储器28和处理单元16)的总线18。
总线18表示几类总线结构中的一种或多种,包括存储器总线或者存储器控制器,***总线,图形加速端口,处理器或者使用多种总线结构中的任意总线结构的局域总线。举例来说,这些体系结构包括但不限于工业标准体系结构(ISA)总线,微通道体系结构(MAC)总线,增强型ISA总线、视频电子标准协会(VESA)局域总线以及***组件互连(PCI)总线。
电子设备12典型地包括多种计算机***可读介质。这些介质可以是任何能够被电子设备12访问的可用介质,包括易失性和非易失性介质,可移动的和不可移动的介质。
***存储器28可以包括易失性存储器形式的计算机***可读介质,例如随机存取存储器(RAM)30和/或高速缓存存储器32。电子设备12可以进一步包括其它可移动/不可移动的、易失性/非易失性计算机***存储介质。仅作为举例,存储***34可以用于读写不可移动的、非易失性磁介质(图7未显示,通常称为“硬盘驱动器”)。尽管图7中未示出,可以提供用于对可移动非易失性磁盘(例如“软盘”)读写的磁盘驱动器,以及对可移动非易失性光盘(例如CD-ROM,DVD-ROM或者其它光介质)读写的光盘驱动器。在这些情况下,每个驱动器可以通过一个或者多个数据介质接口与总线18相连。存储器28可以包括至少一个程序产品,该程序产品具有一组(例如至少一个)程序模块,这些程序模块被配置以执行本发明各实施例的功能。
具有一组(至少一个)程序模块42的程序/实用工具40,可以存储在例如存储器28中,这样的程序模块42包括——但不限于——操作***、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。程序模块42通常执行本发明所描述的实施例中的功能和/或方法。
电子设备12也可以与一个或多个外部设备14(例如键盘、指向设备、显示器24等)通信,还可与一个或者多个使得用户能与该电子设备12交互的设备通信,和/或与使得该电子设备12能与一个或多个其它计算设备进行通信的任何设备(例如网卡,调制解调器等等)通信。这种通信可以通过输入/输出(I/O)接口22进行。并且,电子设备12还可以通过网络适配器20与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。如图所示,网络适配器20通过总线18与计算机设备12的其它模块通信。应当明白,尽管图7中未示出,可以结合电子设备12使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID***、磁带驱动器以及数据备份存储***等。
处理单元16通过运行存储在***存储器28中的程序,从而执行各种功能应用以及数据处理,例如实现本发明实施例所提供的数据处理方法:
也即,所述处理单元执行所述程序时实现:在Oracle数据库中创建表,并在所述表中设置BLOB类型字段;获取图文件,并将所述图文件转换成二进制数据流;将所述二进制数据流写入所述BLOB类型字段。
当然,本领域技术人员可以理解,处理单元还可以实现本发明任意实施例所提供的数据处理方法。
本发明实施例还提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如本申请所有发明实施例提供的数据处理方法:
也即,该程序被处理器执行时实现:在Oracle数据库中创建表,并在所述表中设置BLOB类型字段;获取图文件,并将所述图文件转换成二进制数据流;将所述二进制数据流写入所述BLOB类型字段。
当然,本发明实施例所提供的一种计算机可读存储介质,其上存储的计算机程序不限于如上所述的方法操作,还可以执行本发明实施例所提供的数据处理方法的相关操作。
本发明实施例的计算机存储介质,可以采用一个或多个计算机可读的介质的任意组合。计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的***、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本文件中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行***、装置或者器件使用或者与其结合使用。
计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括——但不限于——电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行***、装置或者器件使用或者与其结合使用的程序。
计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括——但不限于——无线、电线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言或其组合来编写用于执行本发明操作的计算机程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
注意,上述仅为本发明的较佳实施例及所运用技术原理。本领域技术人员会理解,本发明不限于这里所述的特定实施例,对本领域技术人员来说能够进行各种明显的变化、重新调整和替代而不会脱离本发明的保护范围。因此,虽然通过以上实施例对本发明进行了较为详细的说明,但是本发明不仅仅限于以上实施例,在不脱离本发明构思的情况下,还可以包括更多其他等效实施例,而本发明的范围由所附的权利要求范围决定。

Claims (10)

1.一种数据处理方法,其特征在于,包括:
在Oracle数据库中创建表,并在所述表中设置BLOB类型字段;
获取图文件,并将所述图文件转换成二进制数据流;
将所述二进制数据流写入所述BLOB类型字段。
2.根据权利要求1所述的数据处理方法,其特征在于,在Oracle数据库中创建表,并在所述表中设置BLOB类型字段之后,还包括:
创建用户,并将所述表授权给所述用户。
3.根据权利要求2所述的数据处理方法,其特征在于,所述获取图文件,包括:
接收所述用户发起的写数据请求;
根据所述写数据请求获取所述图文件。
4.根据权利要求1所述的数据处理方法,其特征在于,所述图文件有多个,所述将所述图文件转换成二进制数据流,包括:
按照批处理数量阈值对所述图文件分组;
按照所述分组将所述图文件转换成二进制数据流。
5.根据权利要求1至4任意一项所述的数据处理方法,其特征在于,所述将所述二进制数据流写入所述BLOB类型字段,包括:
构建SQL写数据语句;
将所述二进制数据流作为写参数写入所述SQL写数据语句;
执行所述SQL写数据语句,以将所述二进制数据流写入所述BLOB类型字段。
6.根据权利要求2所述的数据处理方法,其特征在于,在将所述二进制数据流写入所述BLOB类型字段之后,还包括:
接收所述用户发起的读数据请求;
根据所述读数据请求从所述BLOB类型字段读取所述二进制数据流;
将所述二进制数据流转换成所述图文件。
7.根据权利要求6所述的数据处理方法,其特征在于,所述根据所述读数据请求从所述BLOB类型字段读取所述二进制数据流,包括:
构建SQL读数据语句;
从所述读数据请求获取读参数,并将所述读参数写入所述SQL读数据语句;
执行所述SQL读数据语句,以从所述BLOB类型字段读取所述二进制数据流。
8.一种数据处理装置,其特征在于,包括:
设置模块,用于在Oracle数据库中创建表,并在所述表中设置BLOB类型字段;
获取模块,用于获取图文件;
第一转换模块,用于将所述图文件转换成二进制数据流;
写数据模型,用于将所述二进制数据流写入所述BLOB类型字段。
9.一种电子设备,包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时实现如权利要求1至7中任一所述的方法。
10.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1至7中任一所述的方法。
CN202011149943.2A 2020-10-23 2020-10-23 数据处理方法、装置、设备和存储介质 Pending CN112307021A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202011149943.2A CN112307021A (zh) 2020-10-23 2020-10-23 数据处理方法、装置、设备和存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202011149943.2A CN112307021A (zh) 2020-10-23 2020-10-23 数据处理方法、装置、设备和存储介质

Publications (1)

Publication Number Publication Date
CN112307021A true CN112307021A (zh) 2021-02-02

Family

ID=74327626

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202011149943.2A Pending CN112307021A (zh) 2020-10-23 2020-10-23 数据处理方法、装置、设备和存储介质

Country Status (1)

Country Link
CN (1) CN112307021A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113076325A (zh) * 2021-03-25 2021-07-06 上海达梦数据库有限公司 一种大字段数据处理方法、装置、设备及存储介质

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106156301A (zh) * 2016-06-30 2016-11-23 上海达梦数据库有限公司 一种大字段数据的处理方法及装置
CN106844678A (zh) * 2017-01-24 2017-06-13 山东浪潮商用***有限公司 一种Mybatis数据源与连接池的交互方法

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106156301A (zh) * 2016-06-30 2016-11-23 上海达梦数据库有限公司 一种大字段数据的处理方法及装置
CN106844678A (zh) * 2017-01-24 2017-06-13 山东浪潮商用***有限公司 一种Mybatis数据源与连接池的交互方法

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113076325A (zh) * 2021-03-25 2021-07-06 上海达梦数据库有限公司 一种大字段数据处理方法、装置、设备及存储介质

Similar Documents

Publication Publication Date Title
CN107391653B (zh) 一种分布式NewSQL数据库***及图片数据储存方法
CN108519967B (zh) 图表可视化方法、装置、终端和存储介质
US9298775B2 (en) Changing the compression level of query plans
WO2019140828A1 (zh) 电子装置、分布式***日志查询方法及存储介质
US10452655B2 (en) In-memory cursor duration temp tables
EP2763055B1 (en) A telecommunication method and mobile telecommunication device for providing data to a mobile application
CN111949693B (zh) 一种数据处理装置、数据处理方法、存储介质及电子设备
CN103970758A (zh) 数据库访问***及方法
CN113051268A (zh) 数据查询方法、数据查询装置、电子设备及存储介质
CN104881466A (zh) 数据分片的处理以及垃圾文件的删除方法和装置
CN111078205A (zh) 一种模块化编程方法、装置、存储介质及电子设备
CN111694866A (zh) 数据搜索及存储方法、数据搜索***、装置、设备及介质
CN112463800A (zh) 数据读取方法、装置、服务器及存储介质
CN112949269A (zh) 可视化数据分析报表的生成方法、***、设备及存储介质
CN110716960B (zh) 一种数据库查询方法、装置、设备及存储介质
CN110175128B (zh) 一种相似代码案例获取方法、装置、设备和存储介质
CN109033456B (zh) 一种条件查询方法、装置、电子设备和存储介质
CN112307021A (zh) 数据处理方法、装置、设备和存储介质
CN112506490A (zh) 一种接口生成方法、装置、电子设备及存储介质
CN111198917A (zh) 数据处理方法、装置、设备及存储介质
CN111143461A (zh) 映射关系处理***、方法和电子设备
CN114238391A (zh) 数据分页查询方法、装置、电子设备及存储介质
CN112950833B (zh) 一种门禁设备的授权方法、装置、设备及存储介质
US20060136361A1 (en) Extensible, customizable database-driven row-level database security
US11074244B1 (en) Transactional range delete in distributed databases

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