- 浏览: 223161 次
- 性别:
- 来自: 重庆
文章分类
最新评论
-
fitzsu:
关于中文占多少字节的问题应该是跟字符集相关的,跟类型无关的对吗 ...
Oracle CHAR,VARCHAR,VARCHAR2,nvarchar类型的区别与使用 -
showzh:
...
Oracle CHAR,VARCHAR,VARCHAR2,nvarchar类型的区别与使用 -
ltian:
实话实说,让我云里雾里!不知道Hibernate缓存能力和云计 ...
OO + 分布式计算 = 软件架构的方向 -
蔡华江:
5.如果数据间引用不存在环路,还可以用递归查询来完成如果出现环 ...
一道数据库开发面试题 -
zydar:
自己不改~
springside3版本qWikiOffice
create or replace procedure bsd_sendemail(p_receiver varchar2,
p_sub varchar2,
p_txt varchar2) is
p_user varchar2 (30) := '';
p_pass varchar2 (30) := '';
p_sendor varchar2 (20) := 'Gnie';
p_server varchar2 (20) := 'Mail_Server_IP';
p_port number := 25;
p_need_smtp number := 0;
p_subject varchar2 (4000);
l_crlf varchar2 (2) := utl_tcp.crlf;
l_sendoraddress varchar2 (4000);
l_splite varchar2 (10) := '++';
boundary constant varchar2 (256) := '-----BYSUK';
first_boundary constant varchar2(256) := '--' || boundary || l_crlf;
last_boundary constant varchar2 (256) := '--' || boundary || '--' ||
l_crlf;
multipart_mime_type constant varchar2(256) := 'multipart/mixed;boundary="' ||
boundary || '"';
type address_list is table of varchar2(100) index by binary_integer;
my_address_list address_list ;
---------------------------------------分割邮件地址----------------------------------------------
procedure p_splite_str(p_str varchar2, p_splite_flag int default 1) is
l_addr varchar2(254) := '';
l_len int;
l_str varchar2(4000);
j int := 0; --表示邮件地址或者附件的个数
begin
/*处理接收邮件地址列表,包括去空格、将;转换为,等*/
l_str := trim(rtrim(replace(replace(p_str, ';', ','), '', ''), ','));
l_len := length(l_str);
for i in 1 .. l_len loop
if substr(l_str, i, 1) <> ',' then
l_addr := l_addr || substr(l_str, i, 1);
else
j := j + 1;
if p_splite_flag = 1 then
--表示处理邮件地址
--前后需要加上'<>',否则很多邮箱将不能发送邮件
l_addr := '<' || l_addr || '>';
--调用邮件发送过程
my_address_list(j) := l_addr;
end if;
l_addr := '';
end if;
if i = l_len then
j := j + 1;
if p_splite_flag = 1 then
--调用邮件发送过程
l_addr := '<' || l_addr || '>';
my_address_list(j) := l_addr;
end if;
end if;
end loop;
end;
------------------------------------------------写邮件头和邮件内容------------------------------------------
procedure write_data(p_conn in out nocopy utl_smtp.connection,
p_name in varchar2,
p_value in varchar2,
p_splite varchar2 default ':',
p_crlf varchar2 default l_crlf) is
begin
/*utl_raw.cast_to_raw对解决中文乱码问题很重要*/
utl_smtp.write_raw_data(p_conn,
utl_raw.cast_to_raw(convert(p_name || p_splite ||
p_value || p_crlf,
'ZHS16CGB231280')));
end;
----------------------------------------写mime邮件尾部-----------------------------------------------------
procedure end_boundary(conn in out nocopy utl_smtp.connection,
last in boolean default false) is
begin
utl_smtp.write_data(conn, utl_tcp.crlf);
if (last) then
utl_smtp.write_data(conn, last_boundary);
end if;
end;
---------------------------------------------真正发送邮件的过程--------------------------------------------
procedure p_email(p_sendoraddress2 varchar2, --发送地址
p_receiveraddress2 varchar2) --接受地址
is
l_conn utl_smtp.connection; --定义连接
begin
/*初始化邮件服务器信息,连接邮件服务器*/
l_conn := utl_smtp.open_connection(p_server, p_port);
utl_smtp.helo(l_conn, p_server);
/*smtp服务器登录校验*/
if p_need_smtp = 1 then
utl_smtp.command(l_conn, 'AUTHLOGIN', '');
utl_smtp.command(l_conn,
utl_raw.cast_to_varchar2(utl_encode.base64_encode(utl_raw.cast_to_raw(p_user))));
utl_smtp.command(l_conn,
utl_raw.cast_to_varchar2(utl_encode.base64_encode(utl_raw.cast_to_raw(p_pass))));
end if;
/*设置发送地址和接收地址*/
utl_smtp.mail(l_conn, p_sendoraddress2);
utl_smtp.rcpt(l_conn, p_receiveraddress2);
/*设置邮件头*/
utl_smtp.open_data(l_conn);
/*设置日期*/
--write_data(l_conn,'Date',to_char(sysdate-1/3,'ddMonyyhh24:mi:ss'));
/*设置发送人*/
write_data(l_conn, 'From', p_sendor);
/*设置接收人*/
write_data(l_conn, 'To', p_receiver);
/*设置邮件主题*/
select replace('=?GB2312?B?' ||
utl_raw.cast_to_varchar2(utl_encode.base64_encode(rawtohex(p_sub))) || '?=',
utl_tcp.crlf,
'') into p_subject from dual;
write_data(l_conn, 'Subject', p_subject);
write_data(l_conn, 'Content-Type', multipart_mime_type);
utl_smtp.write_data(l_conn, utl_tcp.crlf);
utl_smtp.write_data(l_conn, first_boundary);
write_data(l_conn, 'Content-Type', 'text/html;charset=gb2312');
--单独空一行,否则,正文内容不显示
utl_smtp.write_data(l_conn, utl_tcp.crlf);
/*设置邮件正文
把分隔符还原成chr(10)。这主要是为了shell中调用该过程,如果有多行,则先把多行的内容合并成一行,并用l_splite分隔
然后用l_crlf替换chr(10)。这一步是必须的,否则将不能发送邮件正文有多行的邮件
*/
write_data(l_conn,
'',
replace(replace(p_txt, l_splite, chr(10)), chr(10), l_crlf),
'',
'');
end_boundary(l_conn);
/*关闭数据写入*/
utl_smtp.close_data(l_conn);
/*关闭连接*/
utl_smtp.quit(l_conn);
end;
---------------------------------------------主过程-----------------------------------------------------
begin
l_sendoraddress := '<' || p_sendor || '>';
p_splite_str(p_receiver); --处理邮件地址
for k in 1 .. my_address_list.count loop
p_email(l_sendoraddress, my_address_list(k));
end loop;
/*处理邮件地址,根据逗号分割邮件*/
end;
发表评论
-
Merge into bug?
2014-07-02 10:54 3843在ORACLE 11.2.0.3上执行merge into ... -
AWR 报告关键部分
2014-06-09 10:38 4591、后台等待事件 2、按Gets排序的SQL 3、按读取 ... -
DBLinks 新增加字段后,提示标识符无效
2014-06-06 15:03 1125在用DBlinks同步数据中,原表和目标表增加了 ... -
PowerDesigner 之 report html
2014-04-09 12:04 693谁说的PowerDesigner 导出的Html不好看?在相对 ... -
Oracle之行转列
2014-04-04 14:53 551select regexp_substr(in_code_k ... -
用 Oracle 数据库 10g 通过回收浪费的空间、联机重组表格和评估增长的趋势,有效地在段中进行存储管理
2010-06-22 14:45 2045近来,有人要求我评估一个与 Oracle 数据库竞争的 RDB ... -
官方的linux下卸载oracle步骤
2010-05-19 16:40 17185 Removing Oracle SoftwareThis ... -
Oracle服务器如何科学组织RAID阵列
2010-05-11 13:37 1371我们在部署服务器时通 ... -
通过Oracle发送Email
2010-05-11 13:14 1368本篇是通过Oracle10g发送Email实例,该Proce ... -
Oracle PL/SQL编程规范指南
2010-05-11 12:31 1348一、PL/SQL编程规范之大 ... -
全面认识Oracle数据库字符集
2010-05-01 14:16 901什么是Oracle字符集 Oracle字符集是一个字节数 ... -
Oracle 系统表大全
2010-04-21 15:04 743数据字典dict总是属于Oracle用户sys的。 1、用户 ... -
Oracle中杀不掉的锁
2010-04-21 14:29 712一些ORACLE中的进程被杀掉后,状态被置为"kil ... -
flashback table
2010-04-07 10:50 1692小心误删除了某个表中 ... -
clob_to_varchar2
2010-03-18 18:31 817CREATE OR REPLACE FUNCTION kf_c ... -
一道数据库开发面试题
2010-03-18 17:56 1693已知表route,字段和内容如下: 起始节点 终止节点 ... -
PL/SQL的递归调用
2010-03-18 17:51 1069已知表route,字段和内容如下: 起始节点 终止节点 距离 ... -
分析函数3(Top/Bottom N、First/Last、NTile)
2010-03-18 17:42 1057一、带空值的排列: 假如被排列的数据中含有空值呢? SQL& ... -
利用oracle快照dblink解决数据库表同步问题
2009-12-30 08:48 1009--1、在目的数据库上,创建dblink drop publi ... -
Oracle 示例:Oracle Warehouse Builder 11g
2009-12-09 12:07 946http://www.oracle.com/technolog ...
相关推荐
标题中的"0008-rtl_bsd_drv_v195.00.tgz"是一个针对FreeBSD操作系统的RTL(Realtek)网卡驱动程序的压缩包,版本号为v195.00。这个文件主要是为了解决在FreeBSD 9.2版本中,系统无法识别rtl8168系列网卡的问题。rtl...
bsd_type.h
总的来说,"BSP_Press+Temp_Demo_传感器_压力传感器86BSD_DEMO_86BSD"项目提供了一个完整的压力和温度监测解决方案,涵盖了从硬件接口到软件驱动,再到数据处理的全链条。这对于任何需要压力和温度测量的系统设计者...
BSD_ROOTKIT设计 BSD_ROOTKIT设计
**BSD(贝叶斯逐步判别)是一种统计分析方法,常用于分类问题,特别是当数据具有多类别的特征时。该方法基于贝叶斯定理,通过逐步选择最能区分不同类别的特征来构建判别模型。在本资料中,作者提供了一个名为“BSD.m...
_bsd_types.h
【标题】"BSD_ixp400AccessLibrary-3_0_1.zip" 提供的是一种针对IXP400处理器的访问库,版本为3.0.1,该库可能用于开发或维护基于BSD(Berkeley Software Distribution)操作系统的嵌入式系统。在这一版本中,开发者...
标题中的“xc2s_ibis.zip__1532.bsd_ibis_ibis xilinx_xilinx IBIS模型”提到了“xc2s”,这代表Xilinx公司的Spartan系列FPGA,具体是Spartan-2系列。"ibis"指的是IBIS(Input/Output Buffer Information ...
2.11BSD_X44(TBA) 2.11BSD在BSD的历史上是独一无二的,直到最近十年,它仍在收到其代码库的补丁程序。 也是唯一一个接收从4BSD的多个版本反向移植的补丁程序的BSD。 2.11BSD_X44是2.11BSD并延续了这一传统。 用...
4.4BSD操作系统设计与实现,值得研究
FreeBSD 中文使用手册 本手册适用于安装 FreeBSD 5.4-RELEASE 和 FreeBSD 6.0-RELEASE 以及它们的日常使用。
此文件对您来说没那么重要,请不要下载,仅仅为了积分上传,
FreeBSD的内核架构基于Berkeley Software Distribution (BSD)系统,它的设计目标是提供高性能、可移植性和可靠性。内核主要由以下几个部分组成: - **调度器**:负责进程的调度,确保系统资源的公平分配。 - **内存...
PCBSD是基于freebsd的以桌面应用为目的的操作系统,...为解决bsd安装软件的难题,除了与原有的 FreeBSD Ports 系统相容外,pcbsd开发了一种全新的方式,PBI,通过PBI安装软件跟windows中一样,只需要双击就可以了。
代码如下:create or replace procedure bsd_sendemail (p_receiver varchar2,p_sub varchar2,p_txt varchar2) is p_user varchar2(30) := ”; p_pass varchar2(30) := ”; p_sendor varchar2(20) := ‘Gnie’;...
socket_4.4BSD_Lite 套接字源码
BSD68和BSD100是两个在计算机视觉和图像处理领域中广泛使用的数据集,尤其在深度学习的训练和评估中占据重要地位。这两个数据集由加利福尼亚大学伯克利分校的研究人员创建,因此通常被称为Berkeley Segmentation ...
标题中的"bsd-mailx_8.1.2-0.20071201cvs-3_i386.deb"和"mailx_20071201-3_all.deb"指的是两个不同的邮件处理软件的 Debian 包。`bsd-mailx` 是一个基于 BSD 的邮件传输代理,而 `mailx` 是一个命令行接口的邮件...
【BSD\L_bsdl_bsdl下载网】是一个与编程相关的压缩包,主要包含源代码文件,用于在Basic语言环境中测试BGA(Ball Grid Array)技术。这个压缩包的名称"bsdl.rar"暗示了它可能与某种名为"BSDL"(可能是"Ball Grid ...