楼主: jtlyr

一条sql语句为何在过程中编译不通过?

[复制链接]
论坛徽章:
86
2015中国数据库技术大会纪念徽章
日期:2015-04-24 16:04:24马上有车
日期:2014-02-19 11:55:14马上有车
日期:2014-02-18 16:41:112014年新春福章
日期:2014-02-18 16:41:11优秀写手
日期:2013-12-18 09:29:11日产
日期:2013-10-17 08:44:39马自达
日期:2013-08-26 16:28:022013年新春福章
日期:2013-02-25 14:51:24ITPUB 11周年纪念徽章
日期:2012-10-23 16:55:51马上有房
日期:2014-02-19 11:55:14
11#
发表于 2005-3-6 11:26 | 只看该作者
3

e2.jpg (113.38 KB, 下载次数: 117)

e2.jpg

使用道具 举报

回复
论坛徽章:
86
2015中国数据库技术大会纪念徽章
日期:2015-04-24 16:04:24马上有车
日期:2014-02-19 11:55:14马上有车
日期:2014-02-18 16:41:112014年新春福章
日期:2014-02-18 16:41:11优秀写手
日期:2013-12-18 09:29:11日产
日期:2013-10-17 08:44:39马自达
日期:2013-08-26 16:28:022013年新春福章
日期:2013-02-25 14:51:24ITPUB 11周年纪念徽章
日期:2012-10-23 16:55:51马上有房
日期:2014-02-19 11:55:14
12#
发表于 2005-3-6 11:27 | 只看该作者
4

e3.jpg (48.84 KB, 下载次数: 118)

e3.jpg

使用道具 举报

回复
论坛徽章:
86
2015中国数据库技术大会纪念徽章
日期:2015-04-24 16:04:24马上有车
日期:2014-02-19 11:55:14马上有车
日期:2014-02-18 16:41:112014年新春福章
日期:2014-02-18 16:41:11优秀写手
日期:2013-12-18 09:29:11日产
日期:2013-10-17 08:44:39马自达
日期:2013-08-26 16:28:022013年新春福章
日期:2013-02-25 14:51:24ITPUB 11周年纪念徽章
日期:2012-10-23 16:55:51马上有房
日期:2014-02-19 11:55:14
13#
发表于 2005-3-6 11:28 | 只看该作者
5

e4.jpg (42.31 KB, 下载次数: 124)

e4.jpg

使用道具 举报

回复
论坛徽章:
86
2015中国数据库技术大会纪念徽章
日期:2015-04-24 16:04:24马上有车
日期:2014-02-19 11:55:14马上有车
日期:2014-02-18 16:41:112014年新春福章
日期:2014-02-18 16:41:11优秀写手
日期:2013-12-18 09:29:11日产
日期:2013-10-17 08:44:39马自达
日期:2013-08-26 16:28:022013年新春福章
日期:2013-02-25 14:51:24ITPUB 11周年纪念徽章
日期:2012-10-23 16:55:51马上有房
日期:2014-02-19 11:55:14
14#
发表于 2005-3-6 11:29 | 只看该作者
6

e5.jpg (101.01 KB, 下载次数: 225)

e5.jpg

使用道具 举报

回复
论坛徽章:
86
2015中国数据库技术大会纪念徽章
日期:2015-04-24 16:04:24马上有车
日期:2014-02-19 11:55:14马上有车
日期:2014-02-18 16:41:112014年新春福章
日期:2014-02-18 16:41:11优秀写手
日期:2013-12-18 09:29:11日产
日期:2013-10-17 08:44:39马自达
日期:2013-08-26 16:28:022013年新春福章
日期:2013-02-25 14:51:24ITPUB 11周年纪念徽章
日期:2012-10-23 16:55:51马上有房
日期:2014-02-19 11:55:14
15#
发表于 2005-3-6 11:32 | 只看该作者
有几个疑问
1.SELECT INTO SELECT应该是DML吧?为什么不能直接在存储过程里写?(编译错误)
2.换成动态SQL则可以编译通过,并且直接运行SQL也没有问题,但是为什么运行编译好的存储过程则报ORA-06502

使用道具 举报

回复
论坛徽章:
86
ITPUB元老
日期:2005-02-28 12:57:002012新春纪念徽章
日期:2012-01-04 11:49:542012新春纪念徽章
日期:2012-02-13 15:13:202012新春纪念徽章
日期:2012-02-13 15:13:202012新春纪念徽章
日期:2012-02-13 15:13:202012新春纪念徽章
日期:2012-02-13 15:13:202012新春纪念徽章
日期:2012-02-13 15:13:20咸鸭蛋
日期:2012-05-08 10:27:19版主8段
日期:2012-05-15 15:24:112013年新春福章
日期:2013-02-25 14:51:24
16#
发表于 2005-3-6 11:34 | 只看该作者
存储过程中使用的是pl/sql引擎,有些sql引擎支持的sql在pl/sql引擎中不支持,也就是说通常pl/sql引擎落后一步,这在8i中有很多这样的sql都是存在的,9i中有改进。不过,你要非这么用,可以试一下使用 动态sql来执行这sql

使用道具 举报

回复
论坛徽章:
86
2015中国数据库技术大会纪念徽章
日期:2015-04-24 16:04:24马上有车
日期:2014-02-19 11:55:14马上有车
日期:2014-02-18 16:41:112014年新春福章
日期:2014-02-18 16:41:11优秀写手
日期:2013-12-18 09:29:11日产
日期:2013-10-17 08:44:39马自达
日期:2013-08-26 16:28:022013年新春福章
日期:2013-02-25 14:51:24ITPUB 11周年纪念徽章
日期:2012-10-23 16:55:51马上有房
日期:2014-02-19 11:55:14
17#
发表于 2005-3-6 13:43 | 只看该作者
是我的例子有问题。嘿嘿
但是奇怪的是报的错误,一般应该是字符缓冲区太小的错误啊。

e6.jpg (42.65 KB, 下载次数: 133)

e6.jpg

使用道具 举报

回复
论坛徽章:
0
18#
发表于 2005-3-6 22:15 | 只看该作者
各位的讨论令我大开眼界,谢谢大家。

使用道具 举报

回复
论坛徽章:
1
授权会员
日期:2005-10-30 17:05:33
19#
发表于 2005-3-9 18:55 | 只看该作者
最初由 biti_rainy 发布
[B]存储过程中使用的是pl/sql引擎,有些sql引擎支持的sql在pl/sql引擎中不支持,也就是说通常pl/sql引擎落后一步,这在8i中有很多这样的sql都是存在的,9i中有改进。不过,你要非这么用,可以试一下使用 动态sql来执行这sql [/B]


不知道大家还遇到有什么样的语法是pl/sql引擎中不支持的呢?
有看到Tom的《Expert One-on-one Oracle》中讲到分析函数时提过类似的问题,其他就很少见到了。

使用道具 举报

回复
论坛徽章:
0
20#
发表于 2005-3-10 00:42 | 只看该作者
在procedure中dml语音就用execute immediate strsql的方式实现吧

使用道具 举报

回复

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

TOP技术积分榜 社区积分榜 徽章 团队 统计 知识索引树 积分竞拍 文本模式 帮助
  ITPUB首页 | ITPUB论坛 | 数据库技术 | 企业信息化 | 开发技术 | 微软技术 | 软件工程与项目管理 | IBM技术园地 | 行业纵向讨论 | IT招聘 | IT文档
  ChinaUnix | ChinaUnix博客 | ChinaUnix论坛
CopyRight 1999-2011 itpub.net All Right Reserved. 北京盛拓优讯信息技术有限公司版权所有 联系我们 未成年人举报专区 
京ICP备16024965号-8  北京市公安局海淀分局网监中心备案编号:11010802021510 广播电视节目制作经营许可证:编号(京)字第1149号
  
快速回复 返回顶部 返回列表