如何转义 <、> 和 &Oracle PL/SQL 中 html 实体的字符

How to escape lt;, gt;, and amp; characters to html entities in Oracle PL/SQL(如何转义 lt;、gt; 和 amp;Oracle PL/SQL 中 html 实体的字符)
本文介绍了如何转义 <、> 和 &Oracle PL/SQL 中 html 实体的字符的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我需要直接从 oracle PL/SQL 包发送 HTML 电子邮件.这几乎可以正常工作.

I need to send HTML emails directly from oracle PL/SQL package. This works almost fine.

我对从表中提取的某些数据包含诸如 和类似的片段的事实有疑问,这些片段有时被视为 HTML 标签,即使不是,它们也总是被忽略并且从不显示.

I have problem with the fact that some of the data fetched from a table contain things like <S>, <L>, and similar fragments, which sometimes ar treated as HTML tags, and even if not, they are always ignored and never displayed.

因此,我需要在插入电子邮件正文之前转义此列.

So, I need to escape this column before inserting into email body.

是否有自动将html特殊字符转义为实体的功能?还是我需要replace('<', '&lt;', string) 手动所有特殊字符?

Is there a function to escape html special chars into entities automaticly? Or do I need to replace('<', '&lt;', string) manually all the special characters?

推荐答案

可以使用htf.escape_sc函数:

You can use the htf.escape_sc function:

SQL> select htf.escape_sc('Please escape <this> tag') from dual;

HTF.ESCAPE_SC('PLEASEESCAPE<THIS>TAG')
------------------------------------------------------------------
Please escape &lt;this&gt; tag

这篇关于如何转义 &lt;、&gt; 和 &amp;Oracle PL/SQL 中 html 实体的字符的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

SQL to Generate Periodic Snapshots from Transactions Table(用于从事务表生成定期快照的SQL)
MyBatis support for multiple databases(MyBatis支持多个数据库)
Oracle 12c SQL: Missing column Headers in result(Oracle 12c SQL:结果中缺少列标题)
SQL query to find the number of customers who shopped for 3 consecutive days in month of January 2020(查询2020年1月连续购物3天的客户数量)
How to get top 10 data weekly (This week, Previous week, Last month, 2 months ago, 3 month ago)(如何每周获取前十大数据(本周、前一周、上个月、2个月前、3个月前))
Select the latest record for an Id per day - Oracle pl sql(选择每天ID的最新记录-Oracle pl SQL)