当前位置:首页 > 文章列表 > 数据库 > MySQL > LOB的基本操作和工作

LOB的基本操作和工作

来源:tutorialspoint 2023-09-01 13:04:40 0浏览 收藏

编程并不是一个机械性的工作,而是需要有思考,有创新的工作,语法是固定的,但解决问题的思路则是依靠人的思维,这就需要我们坚持学习和更新自己的知识。今天golang学习网就整理分享《LOB的基本操作和工作》,文章讲解的知识点主要包括,如果你对数据库方面的知识点感兴趣,就不要错过golang学习网,在这可以对大家的知识积累有所帮助,助力开发能力的提升。

LOB(即大型对象)是数据库管理系统 (DBMS) 中的一种数据类型,用于存储大量非结构化数据,例如文本、图像和视频。 LOB 数据类型对于存储和操作不适合传统行列结构的数据非常有用,例如文档、图形或音频文件。

在本文中,我们将探讨DBMS和SQL中LOB数据类型的基本操作和工作原理。我们还将提供如何在SQL中使用LOB数据类型来存储和操作大量非结构化数据的示例。

LOB数据类型

有几种类型的LOB数据,包括−

  • BLOB(二进制大对象)− BLOB是一组二进制数据,例如图像、音频或视频文件。BLOB数据以字节序列存储,没有特定的字符集。

  • CLOB(字符大对象) - CLOB 是字符数据的集合,例如文本 文档或 HTML 文件。 CLOB 数据存储为字符序列并具有 特定字符集,例如 UTF-8 或 ASCII

  • NCLOB(国家字符大对象) − NCLOB与CLOB类似,但用于存储使用国家字符集(如中文、日文或韩文)的字符数据。

LOB数据类型的工作原理

LOB数据类型存储在数据库的特殊区域中,称为LOB存储区域。这样可以将LOB数据与数据库的其他部分分开存储和访问,从而在处理大量非结构化数据时提高性能和效率。

LOB数据是使用指针访问的,指针是LOB存储区域中LOB数据位置的引用。指针与其余数据一起存储在数据库中,但实际的 LOB 数据存储在 LOB 存储区域中。这使得数据库能够快速有效地访问 LOB 数据,而无需将整个 LOB 存储在数据库本身中。

LOB列状态

LOB 列可以处于三种状态之一 -

  • NULL − LOB列不包含任何数据。

  • EMPTY - LOB 列不包含数据且长度为零。

  • 已填充 - LOB 列包含数据且长度大于零。

LOB 列的状态可以使用 IS NULL 和 IS EMPTY 谓词来确定。

-- Check if a LOB column is NULL
SELECT doc_id
FROM documents
WHERE doc_text IS NULL;

-- Check if a LOB column is EMPTY
SELECT doc_id
FROM documents
WHERE doc_text IS EMPTY;

-- Check if a LOB column is populated
SELECT doc_id
FROM documents
WHERE doc_text IS NOT NULL AND doc_text IS NOT EMPTY;

需要注意的是,即使 LOB 列的长度不为零,它也可以处于 EMPTY 状态。如果 LOB 列仅包含空格或控制字符,则可能会发生这种情况。要检查这一点,您可以使用 LENGTH 函数来确定 LOB 数据的实际长度。

-- Check if a LOB column is EMPTY but has a non-zero length
SELECT doc_id
FROM documents
WHERE doc_text IS NOT NULL AND doc_text IS EMPTY AND LENGTH(doc_text) > 0;

LOB数据的基本操作

在SQL中,可以对LOB数据执行几个基本操作,包括 -

插入 LOB 数据 - 可以使用 INSERT 语句将 LOB 数据插入到数据库中。 LOB 数据可以指定为字符串、文件或程序变量。

-- Insert a BLOB from a file
INSERT INTO images (image_id, image)
VALUES (1, BFILENAME('IMAGE_DIR', 'image1.jpg'));

-- Insert a CLOB from a string literal
INSERT INTO documents (doc_id, doc_text)
VALUES (1, 'This is the text of the document.');

-- Insert a NCLOB from a program variable
DECLARE
   doc_text CLOB;
BEGIN
   doc_text := 'WELCOME';
   INSERT INTO documents (doc_id, doc_text)
   VALUES (2, doc_text);
END;

更新LOB数据 - 可以使用UPDATE语句更新LOB数据。LOB数据可以指定为字符串字面值、文件或程序变量。

-- Update a BLOB with a file
UPDATE images
SET image = BFILENAME('IMAGE_DIR', 'image2.jpg')
WHERE image_id = 1;

-- Update a CLOB with a string literal
UPDATE documents
SET doc_text = 'This is the updated text of the document.'
WHERE doc_id = 1;

-- Update a NCLOB with a program variable
DECLARE
doc_text CLOB;
BEGIN
doc_text := 'WELCOME';
UPDATE documents
SET doc_text = doc_text
WHERE doc_id = 2;
END;

选择 LOB 数据 - 可以使用“SELECT”语句从数据库中检索 LOB 数据。 LOB 数据可以作为字符串返回或写入文件。

-- Select a BLOB and write it to a file
SELECT image
INTO BFILENAME('IMAGE_DIR', 'image3.jpg')
FROM images
WHERE image_id = 1;

-- Select a CLOB and return it as a string
SELECT doc_text
FROM documents
WHERE doc_id = 1;

-- Select a NCLOB and return it as a string
SELECT doc_text
FROM documents
WHERE doc_id = 2;

删除LOB数据 − 可以使用DELETE语句从数据库中删除LOB数据。

-- Delete LOB data
DELETE FROM images
WHERE image_id = 1;

DELETE FROM documents
WHERE doc_id = 1;

DELETE FROM documents
WHERE doc_id = 2;

LOB数据的高级操作

除了上述描述的基本操作之外,还可以在SQL中对LOB数据执行几个高级操作。

搜索 LOB 数据

LIKE 运算符可用于搜索 LOB 数据中的特定模式。 DBMS_LOB 包还提供了几个用于搜索和操作 LOB 数据的函数。

-- Search a CLOB for a specific pattern
SELECT doc_id
FROM documents
WHERE doc_text LIKE '%specific pattern%';

-- Use the INSTR function to search a CLOB
SELECT doc_id
FROM documents
WHERE INSTR(doc_text, 'specific pattern') > 0;

-- Use the SUBSTR function to extract a portion of a CLOB
SELECT SUBSTR(doc_text, 1, 50)
FROM documents
WHERE doc_id = 1;

比较 LOB 数据

= 运算符可用于比较 LOB 数据是否相等。 DBMS_LOB包还提供了COMPARE函数来比较LOB数据。

-- Compare LOB data for equality
SELECT doc_id
FROM documents
WHERE doc_text = 'This is the text of the document.';

-- Use the COMPARE function to compare LOB data
SELECT doc_id
FROM documents
WHERE COMPARE(doc_text, 'This is the text of the document.') = 0;

截断 LOB 数据

DBMS_LOB软件包提供了TRUNCATE函数,用于将LOB数据截断到指定长度。

-- Truncate a CLOB to 50 characters
UPDATE documents
SET doc_text = TRUNCATE(doc_text, 50)
WHERE doc_id = 1;

复制 LOB 数据

DBMS_LOB包提供了COPY函数,用于将LOB数据从一个LOB复制到另一个LOB。

-- Copy CLOB data from one row to another
DECLARE
   source_doc CLOB;
   target_doc CLOB;
BEGIN
   SELECT doc_text INTO source_doc FROM documents WHERE doc_id = 1;
   SELECT doc_text INTO target_doc FROM documents WHERE doc_id = 2;
   COPY(source_doc, target_doc);
   UPDATE documents SET doc_text = target_doc WHERE doc_id = 2;
END;

连接 LOB 数据

DBMS_LOB包提供了CONCATENATE函数,用于将两个LOB连接在一起。

-- Concatenate two CLOBs together
DECLARE
   doc1 CLOB;
   doc2 CLOB;
   doc3 CLOB;
BEGIN
   SELECT doc_text INTO doc1 FROM documents WHERE doc_id = 1;
   SELECT doc_text INTO doc2 FROM documents WHERE doc_id = 2;
   doc3 := CONCATENATE(doc1, doc2);
   INSERT INTO documents (doc_id, doc_text) VALUES (3, doc3);
END;

结论

在本文中,我们探讨了DBMS和SQL中LOB数据类型的基本操作和工作原理。LOB数据类型适用于存储和操作大量的非结构化数据,如文本、图像和视频。我们还提供了如何在SQL中使用LOB数据类型来存储、更新、选择和删除大量的非结构化数据的示例,以及执行高级操作,如搜索、比较、截断、复制和连接LOB数据。

理论要掌握,实操不能落!以上关于《LOB的基本操作和工作》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

版本声明
本文转载于:tutorialspoint 如有侵犯,请联系study_golang@163.com删除
在 Ubuntu 15.04 服务器上设置 LAMP(Linux、Apache、MySQL/MariaDB、PHP)和 PhpMyAdmin在 Ubuntu 15.04 服务器上设置 LAMP(Linux、Apache、MySQL/MariaDB、PHP)和 PhpMyAdmin
上一篇
在 Ubuntu 15.04 服务器上设置 LAMP(Linux、Apache、MySQL/MariaDB、PHP)和 PhpMyAdmin
使用 Node.js 创建 MySQL 表
下一篇
使用 Node.js 创建 MySQL 表
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 笔灵AI生成答辩PPT:高效制作学术与职场PPT的利器
    笔灵AI生成答辩PPT
    探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
    21次使用
  • 知网AIGC检测服务系统:精准识别学术文本中的AI生成内容
    知网AIGC检测服务系统
    知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
    31次使用
  • AIGC检测服务:AIbiye助力确保论文原创性
    AIGC检测-Aibiye
    AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
    35次使用
  • 易笔AI论文平台:快速生成高质量学术论文的利器
    易笔AI论文
    易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
    44次使用
  • 笔启AI论文写作平台:多类型论文生成与多语言支持
    笔启AI论文写作平台
    笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
    37次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码