trim函数 -oralce 的bug?

farspeed 2002-07-13 09:17:01
我使用pl/sql 块中使用 trim 函数
比如
declare
aa varchar2(10);
begin
aa := ' ';
trim(aa);
exception
when others then
exception work;
end;

这个时候不会跳到exception中,而是oracle的连接通道结束

而这个函数直接在sqlplus中使用没有任何的问题。
比如:
select trim(' aa ') from dual;
结果是正确的。
有兴趣的朋友可以试试看。
当然如果能够得到那位高手的指点,则不胜感激!
...全文
72 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
attt 2003-02-27
  • 打赏
  • 举报
回复
可是在8.16中,怎么用trim会出错呢?
所以都不得不用ltrim和rtrim代替
czhai 2003-02-27
  • 打赏
  • 举报
回复
关注!
hai_yu2000 2003-02-27
  • 打赏
  • 举报
回复
ltrim(rtrim(''))
fxbsmile 2003-02-27
  • 打赏
  • 举报
回复
我的版本是8.17 select trim(' ') 到没什么错,

不过再pl/sql 中 trim('') 一样死掉了,
wzyuandl 2003-02-26
  • 打赏
  • 举报
回复
在使用trim时一定要注意trim的字段不能为空,否则可能会使程序死掉或者出错。你可以用
nvl(字段,0)然后trim试试!
li_yirong 2003-02-26
  • 打赏
  • 举报
回复
这个问题可以这样解决:
TRIM (LEADING ' ' FROM ' ')
li_yirong 2003-02-26
  • 打赏
  • 举报
回复
我也碰到了和你类似的问题,up 一下 !!!
farspeed 2002-07-14
  • 打赏
  • 举报
回复
trim 是oracle的一个函数。但是很多手册上都没有它的使用说明。
另外我的版本是8.1.6
之前我使用这个函数好像没有在意此类问题,无意间发现,拿出来和大家探讨一下!
lg_919 2002-07-14
  • 打赏
  • 举报
回复
以前遇到过同样的问题,在8.1.5版本不会出现问题.在8.1.6版本当中如果是在PL/SQL块当中,trim('')或trim(' ')就会出现你所说的通信管道结束的问题.不知你用的是那个版本.
jlandzpa 2002-07-14
  • 打赏
  • 举报
回复
declare
aa varchar2(10);
bb varchar2(10);
begin
aa := ' ';
bb:=trim(aa);
exception
when others then
exception work;
end;
sjzmdslxj 2002-07-14
  • 打赏
  • 举报
回复
Hi!
trim不是Oracle 的函数,如下:
select trim(' aa ') from dual; 在sql/plus中是不能用的,只能用
ltrim或者rtrim 函数去掉左右空格,
如下:
select ltrim(rtrim(' aa ') From dual;
你用select trim(' aa ') from dual;时难道没有报
数据猎无效吗?
haode 2002-07-13
  • 打赏
  • 举报
回复
trim是消空格的方法,它返回一个消去前后空格的字符串,但是原字符串中间的
空格还给予保留。

上边的那个例子,你把一个" "用trim,返回给你的是一个空串,而不是null

对" aa "用trim和对" a a "用trim,结果是不同的,呵呵
PowerBI系列之Power Query专题1.  获取数据 数据源种类介绍和获取Excel数据源输入数据和拷贝数据:创建辅助表解析Json/XML数据格式获取Web网页数据和URL添加动态参数连接数据的四种模式:Import、DirectQuery、Live Connection、Dual双 属于混合模式连接数据库:Sql server、 Mysql(直连但是必须先安装一个mysql插件)DirectQuery直连查询:Sql serverODBC方式获取数据表关联或多个Sql或调用存储过程获取数据SQL中动态传参和自定义函数: sql中使用参数或数据库名称使用参数连接Sharepoint和OneDrive数据源连接Dataset和Dataflow 替换本地数据源为Sharepoint数据源并保留数据处理操作 终止当前数据刷新Loading:Cancel Query数据源设置-重置数据连接凭证PBIDS连接数据源创建和使用报表模块(输入或值列表)利用报表模板和参数控制线下报表数据权限DirectQuery启用自动页面刷新和更改检测管理聚合表提高DirectQuery查询性能动态M查询参数提高DirectQuery查询性能添加数据刷新时间 DateTime.LocalNow()和Getdate()2.  数据清洗和M语言M语言和官方文档介绍PowerQuery中查阅M函数:=#shared, Ctrl+Space提示数据清洗之常用技能:提升标题、更改数据类型、保留删除错误或空行,删除重复项、选择列和删除列、填充单元格、合并列、拆分、提取、替换、条件替换、添加自定义列,添加条件列、添加索引列、分组、添加年月日列、追加和合并查询透视和逆透视以及转置合并单元格的Excel文件处理导入文件夹中多Excel文件并合并解决多文件合并中列顺序不一致使用参数和函数批量导入文件 文本中提取中文、英文、数字等处理双引号转义 列拆分详解解决列名改变错误解决列丢失错误动态显示、排序和重命名列为所有列名添加前缀列名字母大写和分隔符调整Trim标题列中的多余空格如何处理load数据错误为什么load的Excel数据有null空行为什么load的Excel数据标题在第二行灵活添加占位符规范同类相似数据数据按多列排序为分组添加Index序号分组内值合并诊断工具分析数据处理过程PowerQuery小技巧分享 新冠病例活动轨迹地图标识 

17,377

社区成员

发帖
与我相关
我的任务
社区描述
Oracle 基础和管理
社区管理员
  • 基础和管理社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧