社区
基础和管理
帖子详情
为什么运行exec无法执行存储过程,提示无效sql语句
cyc123007512
2010-09-28 09:32:09
create or replace procedure out_date is
begin
dbms_output.put_line(sysdate);
end out_date;
exec out_date;
---在pl/sql中执行exec out_date提示sql语法错误
...全文
2480
10
打赏
收藏
为什么运行exec无法执行存储过程,提示无效sql语句
create or replace procedure out_date is begin dbms_output.put_line(sysdate); end out_date; exec out_date; ---在pl/sql中执行exec out_date提示sql语法错误
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
10 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
心中的彩虹
2010-09-30
打赏
举报
回复
[Quote=引用 8 楼 anyi25_it 的回复:]
要看运行的环境和平台了!
[/Quote]
begin
ZHUYE;
end;
心中的彩虹
2010-09-28
打赏
举报
回复
[Quote=引用楼主 cyc123007512 的回复:]
create or replace procedure out_date is
begin
dbms_output.put_line(sysdate);
end out_date;
exec out_date;
---在pl/sql中执行exec out_date提示sql语法错误
[/Quote]
你是在新建的 sql 窗口运行的话这样
begin
out_date;
end;
结果在输出显示
在新建的 命令窗口 便可以像你那样直接来
Connected to Oracle Database 10g Enterprise Edition Release 10.2.0.1.0
Connected as scott
SQL> exec out_date;
/
PL/SQL procedure successfully completed
SQL> set serveroutput on
SQL> /
28-9月 -10
PL/SQL procedure successfully completed
applefzu
2010-09-28
打赏
举报
回复
在plsql command窗口执行 要多个 “/”
gelyon
2010-09-28
打赏
举报
回复
在plsql developer的sql windows 执行,要这样:
begin
out_date;
end;
如果在SQL Tools中执行的话,你的 exec out_date;这样是没问题的!
caofaping
2010-09-28
打赏
举报
回复
[Quote=引用 3 楼 minitoy 的回复:]
在plsql command窗口执行或者在sqlplus里执行.不要在plsql developer的sql windows 执行.
[/Quote]
+1
minitoy
2010-09-28
打赏
举报
回复
在plsql command窗口执行或者在sqlplus里执行.不要在plsql developer的sql windows 执行.
cyc123007512
2010-09-28
打赏
举报
回复
什么意思?
[Quote=引用 1 楼 ngx20080110 的回复:]
我這邊沒出錯,你試一下
begin
out_date;
end;
[/Quote]
ngx20080110
2010-09-28
打赏
举报
回复
我這邊沒出錯,你試一下
begin
out_date;
end;
anyi25_it
2010-09-28
打赏
举报
回复
要看运行的环境和平台了!
SQL Server 中
EXEC
与 SP_
EXEC
UTESQL 的区别.doc
SQL Server 中
EXEC
与 SP_
EXEC
UTESQL 的区别 MSSQL为我们提供了两种动态
执行
SQL语句
的命令,分别是
EXEC
和 SP_
EXEC
UTESQL ,我们先来看一下两种方式的用法。 先建立一个表,并添加一些数据来进行演示: 复制代码 CREATE TABLE t_student( Id INT NOT NULL, Name NVARCHAR (10) NULL, Age TINYINT NULL, School NVARCHAR(20) NULL, Class NVARCHAR(10) NULL, Score FLOAT NULL, CONSTRAINT [PK_Student_Id] PRIMARY KEY CLUSTERED(Id) ) GO INSERT INTO t_student VALUES(1,'张小红',8,'育才小学','一班',92) INSERT INTO t_student VALUES(2,'王丽丽',8,'育才小学','一班',90) INSERT INTO t_student VALUES(3,'张燕',7,'云华小学','二班',86) INSERT INTO t_student VALUES(4,'刘华',6,'云华小学','二班',85) 复制代码 一、
EXEC
EXEC
命令可以
执行
一个
存储过程
也可以
执行
一个动态
SQL语句
。先来看看怎么
执行
存储过程
: 新建一个
存储过程
SP_GetStudent ,返回 成绩大于90 分的学生: 复制代码 CREATE PROCEDURE [dbo].[Sp_GetStudent] @Score FLOAT, @Nums INT OUTPUT AS BEGIN SET NOCOUNT ON; SELECT * FROM t_student WHERE Score >=@Score SELECT @Nums=COUNT(1) FROM t_student WHERE Score >=@Score IF(@Nums>0) RETURN 1 ELSE RETURN 0 END GO 复制代码 该
存储过程
涉及了 查询操作、返回值和输出参数,我们来看用
EXEC
命令如何调用: 复制代码 DECLARE @return_value int, @OutNums int
EXEC
@return_value = [dbo].[Sp_GetStudent] @Score = 90, @Nums = @OutNums OUTPUT SELECT @OutNums as N'大于90分的人数' SELECT '返回值' = @return_value GO 复制代码
执行
结果: 我们发现
EXEC
执行
存储过程
和我们平时程序
执行
一个方法是几乎一样的,返回值参数 直接就可以等于
存储过程
的
执行
后的返回值,输出参数 在后面需要增加 OUTPUT 关键字。
执行
存储过程
不是重点,重点是
执行
动态
sql语句
,同样看一下例子: DECLARE @TableName NVARCHAR(50),@Sql NVARCHAR(MAX),@Score INT; SET @TableName = 't_Student'; SET @Score = 90; SET @sql = 'SELECT * FROM '+QUOTENAME(@TableName) +'WHERE Score >= '+CAST(@Score AS NVARCHAR(10))
EXEC
(@sql);
执行
结果: 注意:在
执行
拼接SQL 语句的时候,的
EXEC
括号中只允许包含一个字符串变量,但是可以串联多个变量,如果我们直接
执行
这个
SQL语句
: --这是错误的调用
EXEC
('SELECT * FROM '+QUOTENAME(@TableName) +'WHERE Score >= '+CAST(@Score AS NVARCHAR(10)));
执行
就会
提示
错误。但是这样就没有问题: 复制代码 DECLARE @TableName NVARCHAR(50),@Sql NVARCHAR(MAX),@Score INT DECLARE @Sql2 NVARCHAR(MAX) SET @TableName = 't_Student'; SET @Score = 90; SET @sql = 'SELECT * FROM '+QUOTENAME(@TableName) SET @Sql2=' WHERE Score >= '+CAST(@Score AS NVARCHAR(10))
EXEC
(@sql+@sql2) 复制代码
EXEC
执行
拼接
sql语句
的时候不支持 嵌入式参数,如下: DECLARE @OUT_Nums INT,@IN_Score INT,@Sql NVARCHAR(MAX) SET @IN_Score = 90 SET @sql = 'SELECT @Nums=COUNT(1) FROM t_student WHERE Score >= @Score'
EXEC
(@sql) 通过上面的代码发现,
EXEC
执行
拼接的
SQL语句
的时候,不支持内嵌参数,包括输入参数和输出参数。有的时候我们想把得到的count(*)传出来,用
EXEC
是不好办到的。接下来,再来看看SP_
EXEC
UTESQL的使用: 二、SP_
EXEC
UTESQL: SP_
EXEC
UTESQL 是在 SQL 2005中引入的新的系统
存储过程
,也是用来处理动态SQL 语句的。它比
EXEC
更加灵活,首先也
执行
一下第一次的拼接
SQL语句
: DECLARE @TableName NVARCHAR(50),@Sql NVARCHAR(MAX),@Score INT; SET @TableName = 't_Student'; SET @Score = 90; SET @sql = 'SELECT * FROM '+QUOTENAME(@TableName) +'WHERE Score >= '+CAST(@Score AS NVARCHAR(10))
EXEC
SP_
EXEC
UTESQL @sql --注意这里没有了()
执行
结果: SP_
EXEC
UTESQL 支持内嵌参数: 先来看一下SP_
EXEC
UTESQL的语法: sp_
exec
utesql [ @stmt = ] stmt [ {, [@params=] N'@parameter_name data_type [ OUT | OUTPUT ][,...n]' } {, [ @param1 = ] 'value1' [ ,...n ] } ] 说明: [ @stmt = ] stmt 包含 Transact-SQL 语句或批处理的 Unicode 字符串。stmt 必须是 Unicode 常量或 Unicode 变量。不允许使用更复杂的 Unicode 表达式(例如使用 + 运算符连接两个字符串)。不允许使用字符常量。如果指定了 Unicode 常量,则必须使用 N 作为前缀。例如,Unicode 常量 N'sp_who' 是有效的,但是字符常量 'sp_who' 则
无效
。字符串的大小仅受可用数据库服务器内存限制。在 64 位服务器中,字符串大小限制为 2 GB,即 nvarchar(max) 的最大大小。stmt 中包含的每个参数在 @params 参数定义列表和参数值列表中均必须有对应项 [ @params = ] N'@parameter_namedata_type[ ,... n ] ' 包含 stmt 中嵌入的所有参数定义的字符串。字符串必须是 Unicode 常量或 Unicode 变量。每个参数定义由参数名称和数据类型组成。n 是表示附加参数定义的占位符。在 stmt 中指定的每个参数必须在 @params 中定义。如果 stmt 中的 Transact-SQL 语句或批处理不包含参数,则不需要 @params。该参数的默认值为 NULL。 [ @param1 = ] 'value1' 参数字符串中定义的第一个参数的值。该值可以是 Unicode 常量,也可以是 Unicode 变量。必须为 stmt 中包含的每个参数提供参数值。如果 stmt 中的 Transact-SQL 语句或批处理没有参数,则不需要这些值。 [ OUT | OUTPUT ] 指示参数是输出参数。除非是公共语言
运行
(CLR) 过程,否则 text、ntext 和 image 参数均可用作 OUTPUT 参数。使用 OUTPUT 关键字的输出参数可以为游标占位符,CLR 过程除外。 n 附加参数值的占位符。这些值只能为常量或变量,不能是很复杂的表达式(例如函数)或使用运算符生成的表达式。 返回代码值 : 0(成功)或非零(失败) 结果集:从生成 SQL 字符串的所有 SQL 语句返回结果集 看不懂没有关系,通过例子就会非常明白的,依旧还
执行
上面的 SQL 语句: DECLARE @OUT_Nums INT,@IN_Score INT,@Sql NVARCHAR(MAX) SET @IN_Score = 90 SET @sql = 'SELECT @Nums=COUNT(1) FROM t_student WHERE Score >= @Score'
EXEC
SP_
EXEC
UTESQL @sql,N'@Nums INT OUT,@Score INT',@OUT_Nums OUTPUT,@IN_Score SELECT @OUT_Nums AS '人数'
执行
结果: 需要注意的是: 1、要求动态Sql和动态Sql参数列表必须是NVARCHAR 2、动态Sql的参数列表与外部提供值的参数列表顺序必需一致 3、一旦使用了 '@name = value' 形式之后,所有后续的参数就必须以 '@name = value' 的形式传递,比如: DECLARE @OUT_Nums INT,@IN_Score INT,@Sql NVARCHAR(MAX) SET @IN_Score = 90 SET @sql = 'SELECT @Nums=COUNT(1) FROM t_student WHERE Score >= @Score'
EXEC
SP_
EXEC
UTESQL @stmt=@sql,@params=N'@Nums INT OUT,@Score INT',@Nums=@OUT_Nums OUTPUT,@Score=@IN_Score SELECT @OUT_Nums AS '人数' 通过上面的例子已经很清晰的表明了,在
执行
动态SQL 语句的时候,
EXEC
和 SP_
EXEC
UTESQL 的区别了,来总结一下: 1、 性能: 官方描述:sp_
exec
utesql stmt 参数中的 Transact-SQL 语句或批处理在
执行
sp_
exec
utesql 语句时才编译。随后,将编译 stmt 中的内容,并将其作为
执行
计划
运行
。该
执行
计划独立于名为 sp_
exec
utesql 的批处理的
执行
计划。sp_
exec
utesql 批处理不能引用调用 sp_
exec
utesql 的批处理中声明的变量。sp_
exec
utesql 批处理中的本地游标或变量对调用 sp_
exec
utesql 的批处理是不可见的。对数据库上下文所做的更改只在 sp_
exec
utesql 语句结束前有效。如果只更改了语句中的参数值,则 sp_
exec
utesql 可用来代替
存储过程
多次
执行
Transact-SQL 语句。因为 Transact-SQL 语句本身保持不变,仅参数值发生变化,所以 SQL Server 查询优化器可能重复使用首次
执行
时所生成的
执行
计划。 说通俗一点就是:如果用
EXEC
执行
一条动态 SQL 语句,由于每次传入的参数不一样,所以每次生成的 @sql 就不一样,这样每
执行
一次SQL SERVER 就必须重新将要
执行
的动态 Sql 重新编译一次 。但是SP_
EXEC
UTESQL 则不一样,由于将数值参数化,要
执行
的动态 Sql 永远不会变化,只是传入的参数的值在变化,那每次
执行
的时候就不用重新编译,速度和效率自然有所提升。 2、从上面的例子我们已经能够看出 SP_
EXEC
UTESQL 命令比
EXEC
命令更灵活,因为它提供一个接口,该接口及支持输入参数也支持输出参数。 3、
EXEC
执行
纯动态SQL,
执行
时可能
无法
使用预编译的
执行
计划,关键是不安全,可以导致 SQL 注入 ,而 SP_
EXEC
UTESQL
执行
参数化动态 SQL ,
执行
时能使用预编译的
执行
计划,而且保存
存储过程
时就可以确定可以使用的预编译的
执行
计划,而且最重要的是“安全”,天然免疫SQL 注入 作者:Rising Sun 出处:http://www.cnblogs.com/lxblog/ 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利.
pl/sql developer中用
exec
ute调用
存储过程
弹出‘
无效
的
sql语句
’解决方法
转自:http://www.myexception.cn/oracle-management/267605.html——解决方案——————–1、在sql的
执行
窗口中只能这样调用”call OUT_TIME(); “,这样
执行
就是把”call OUT_TIME(); “当成一个
sql语句
,而
exec
OUT_TIME();不是一个
sql语句
,是一个
执行
体,
执行
体调用必须在命令窗口,把这句话当成一个整
尹成Python27天入门到项目实战
尹成Python27天从入门到实战项目!全课665节讲解详细易操作,助力实战项目能力成长,轻松、简单、易懂!day1 python入门与学习方法精确思维与用到才能记忆深刻课程简介课前介绍计算机简介与硬盘概念内存作用计算机小结编程语言简介操作系统简介python版本简介切换python版本修改环境变量交互式编程两种风格python3代码保存必须是utf-8使用IDE了解注释段落打印三引号注释多行三个单引号python代码要严格对齐中文输入字符错误简单数学表达式代码风格三种错误风格系统
执行
指令
运行
结果乱码交互式编程绘图绘制线段与圆形改变颜色绘制奥运五环小结习题day1plus python 常量变量数据类型 常量与变量区别标识符关键字输入输出id求地址type求类型python变量是地址赋值可以改变类型python主要数据类型复数数据类型自适应变长整数intdel作用连续赋值交互对称赋值字符串转化与输入输出编程wmv多行拆分多行归并成一行规范用的常量算术运算符科学计数法与数字越界优先级结合性赋值运算符数据类型转换四舍五入数据提取时间处理作业day2 python字符串与绘图复习变量None变量参与运算没有赋值的情况不会改变绘制立方体绘制五角星时间计算强化实现贷款计算连续输入多个字符串加法与绘图实现显示线段长度数据函数使用快速查阅函数帮助字符串三种风格字符与编号中文字符编号问题字符编号用途统一码转义字符意义转义字符用于字符串print高级用法字符串加法与转换字符串小结python中所有的数据都是对象字符串格式化了解进制图形绘制重点作业以及学习认知方法day3 python运算符与ifelse逻辑语句第一天上午回顾第二天下午回顾1第二天回顾2.7习题解答2.11习题解答2.26作业KaliLinux简介3.4实现五边形面积计算3.7随机字符生成3.8实数误差与四舍五入3.18解答与特殊字符if简介与空格的作用if处理的是逻辑表达式关系运算符针对数值字符串的关系运算符if自动转化Bool类型随机数if缺点且运算符或运算符取反运算符短路效应身份运算符运算符优先级结合性概览pass语句潜台词翻译系统None用途指令翻译系统嵌套嵌套与elif对比以及注意细节习题解答绘图作业与重点day4 语音合成与逻辑循环回顾语音合成简单理解while控制次数WhileElseWhileElse实战whileFloat回顾与ifelse表达式赌博概率分类设计方法-一元二次方程嵌套求有序3个数闰年计算矩形区域随机数ifelse回文数判断10进制转化16进制16进制转十进制暴力穷举无限循环指令循环同步异步黑科技读写内存读写内存无限循环监测重点与作业day5 复杂逻辑循环while与whileelse编程风格循环控制图形绘制while猜数字输入输出重定向while习题分析可以退出的命令系统for初步简介跑分流程结合for循环小结forfor嵌套forfor分析break中断循环contiune结束本次循环双层循环的break与continue分析break与contiue小结一闪一闪亮晶晶循环控制大小与位置对角线绘制圆形口顺时针运动循环等价作业与小结day6 函数实战回顾.算学费输入数据求最大精确划分思维解决最大次大交换数据实现按行显示围棋棋盘绘制国际象棋绘制为什么要用函数函数的四种类型函数的一般形式必须用函数的理由-哥德巴赫函数的本质就是地址函数变量意义函数变量用途装饰器设计模式包含模式函数概念None函数默认参数与返回值作为参数名称参数与位置参数参数副本机制副本练习多个返回值全局变量与局部变量函数内部引用全局变量函数可以嵌套nolocal处理函数嵌套变量函数nonlocalnonlocal总结开房数据查询day7 函数实战与常用数据结构函数的两种类型函数的本质再分析函数地址切换切换功能ifelse配合地址筛选函数收费函数调用过程函数基本小结return小结位置参数与默认参数混合参数填充混合填充错误情况lambda匿名函数可变长函数字符串常识普及字符串特点字符串不可以修改内部字符list列表list用途tuple简介集合运算字典概念in与notin运算符构造表达式转换数据类型系统小结拓展查询作业day8 字符串实战简单回顾eval与
exec
简介字符串的简单规范字符串的截取字符串赋值规范字符串转义字符字符串常见运算符字符串格式化字符串格式化强化字符串编码简介dir与help查看str字符串函数第一个大写以及字符串居中显示打印金字塔count统计字符串出现个数字符串编码注意事项解码失败判断字符串以什么为结束tab键转换find函数与rfind函数day9 字符串高级简单回顾..eval与
exec
简介字符串的简单规范字符串的截取字符串赋值规范字符串转义字符字符串常见运算符字符串格式化字符串格式化强化字符串编码简介dir与help查看str字符串函数第一个大写以及字符串居中显示打印金字塔count统计字符串出现个数字符串编码注意事项解码失败判断字符串以什么为结束tab键转换find函数与rfind函数index函数与rindex函数字符串判断字符串间隔求长度以及左右填充字符串大小写取出最大最小字符替换去除空格简单切割换行切割判断开头大小写切换以及填充0翻译表.字符串模板小结day10 字符串集合与语音识别实战回顾lset初始化风格set增加与去重set删除元素遍历set类型转化set
无法
操作单个元素的赋值set常见方法set常见运算符set关系运算符判断包含set集合判断frozenset字典的基本定义循环字典判断在不在实现插入与更新字典删除字典详解字典与set
无法
嵌套迭代器列表生成式生成器生成器节省内存用于循环生成器yield作用生成器简介测试游戏简介游戏初级修改键盘模拟语音控制游戏实现鼠标模拟代码规范函数简化重用列表与元组小结作业day11 阶段综合练习昨日回顾.堆栈函数模块引用系统模块引用与错误列表生成式的若干方法生成矩阵str与reprpython把输入输出设备当作文件处理写入中文写入英文读取中文读取英文读取错误写入错误处理文件缓存区文件读取若干种方式for循环按行读取数据文件指针seektell数据结构与文件的交互数据查询并保存结果数据查询小结与数据day12downwithoutdata 数据处理开发大数据指令数据清洗的概念初级数据清洗密码排序次数统计QQ密码概率分布QQ号码分类器.开房数据清洗..区域划分省份划分年龄月份划分日划分day12up 数据实战简单回顾12系统默认编码中文编码常见错误字符串切割抓取邮箱抓取用户名与密码排序密码文件统计次数排序.统计文件密码次数密码次数排序day13withoutdata 数据分类与list深入地区分类详解字典分类器数据简单归并数据如何切割数据加密数据解密指令
执行
判断文件夹编程小结列表归并-删除列表归并-下标小结与作业day14down 面向对象编程与深浅拷贝面向对象与过程的差异self用途动态绑定增加属性方法重载运算符的概念有名对象与匿名对象重载运算符的返回值重载运算符多个类型类的拷贝是浅复制深浅拷贝函数调用参数副本原理函数调用可以改变list的元素不可以改变list指向对象当作参数的细节私有变量私有变量用于设计权限私有方法用于设计权限私有变量本质用类的方式读取文件行数密码次数归并数据处理方法简介今日小结作业wmvday14up 暴力穷举与类回顾....排列组合暴力生成穷举密码密码破解必破生成器密码破解小结为啥使用类-代码重用类的一般形式详解self构造函数与析构函数构造函数初始化类的属性最简洁的UI设定窗体的位置以及大小类的实际用途day15down 面向对象数据搜索实战输入处理文本编辑器表格数据树状显示数据搜索可视化第一步实现查询窗体数据搜索可视化第二步实现搜索数据数据搜索可视化第三步实现显示窗体数据可视化第四步显示与搜索串联数据可视化终结作业小结day15up 面向对象设计与图像界面上设计一个类发短信类的方法设计一下短信发送邮件类的设计-设计发邮件类的多文件引用腾讯营销类的设计消息循环消息回掉函数机制lambda按下按钮标签显示文本文本输入框listcombobox选择列表day16up 面向对象与图形界面开发下设计一个类发短信类的方法设计一下短信发送邮件类的设计-设计发邮件类的多文件引用腾讯营销类的设计消息循环消息回掉函数机制lambda按下按钮标签显示文本文本输入框listcombobox选择列表day17 面向对象继承实战昨日小结.,.继承的概念多继承的概念多继承的覆盖私有变量不可以被继承Object类类的常见属性super解决父类重复初始化isinstance多态静态方法类方法数据工具1类的继承数据工具实现小结day18down 正则表达式正则表达式bB贪婪与非贪婪标签.标签解决提取标签名称提取QQ生成邮箱列表工具简单正则表达式编写常见的正则表达式复杂正则表达式编写复杂表达式代码验证作业与小结day18up 正则表达式实践为什么使用正则表达式正则表达式匹配.预编译的概念搜索技能搜索用在找出第一个邮箱手机提取findall字符串切割筛选正则表达式正则表达式替换单个字符判断中括号选择一个字符正则表达式次数正则开头结尾括号与选择正则表达式特殊符号day19down 递归与爬虫实战函数递归模拟文件树文件树事件读取网页抓取邮箱抓取QQ提取http抓取邮箱简单程序框架实现抓取邮箱的框架核心两个函数完成广度遍历深度遍历作.业day19up 深度遍历与广度遍历正则表达式小结最简单递归递归顺序递归求和递归腾讯台阶面试题文件夹的函数遍历文件夹遍历文件夹有层次感栈模拟递归栈模拟递归遍历文件夹栈模拟递归遍历文件夹层次感普及网站提取概念栈修改的逻辑错误广度遍历 day20 正则 爬虫实战行情简介提取页面信息提取股票代码提取股票代码下载功能下载股票批量下载股票抓取1页的股票数据抓取多个页面的股票抓取基金信息作业day21 网络编程与信息安全网络概念UDP协议UDP通信UDP远程控制TCP通信TCP控制测试网站后台网站密码破解作业 day22down 线程通信线程通信线程通信强化线程condition高级线程调度生产者消费者线程池延时线程with作用前台进程后台进程TLS线程独立存储作业day22up 多线程实战多线程核心目标并发主线程与小弟线程多线程解决加速多线程的加速线程冲突基于类实现多线程基于类实现多线程的顺序与乱序互斥锁解决线程冲突死锁-使用锁要注意Rlock解决一个线程反复加锁单线程死锁创建线程的三种风格信号量限制线程数量限定线程数量day23 多进程实战多线程回顾多进程拷贝代码多进程拷贝全局变量获取进程编号subprocess
执行
LinuxShell信号Linux进程小结__name__进程mutiprocessing创建过程join作用进程不可以用全局变量共享数据进程同步进程pipe发送接收数据进程队列进程队列传输数据进程共享数据进程之间共享数组进程共享字典与list简单小结day23down 多进程多线程综合实战读取CSV写入csv单线程统计行数多线程统计行数多进程统计行数多线程检索数据第一步多线程检索赵琳多线程检索找到通知其他人退出多线程检索开放数据并保存同一个文件作业day24up 多进程多线程综合实战多进程检索第一步多进程检索开房数据求平均市值多线程解决平均市值多进程统计平均市值单线程BFS抓取邮箱多线程并行抓取邮箱多线程采集邮箱并保存csv归并多线程归并文件day25down 文件格式处理doc处理系统处理doc与docx文件处理的小结读取并写入xls与xlsx读取网络pdf中文pdftelnet简介登陆Linux登陆Windows小结day25up 时间编程与单元测试时间的简单风格时间格式化抓取年月日计算时间差时间函数计算时间差date小结python2与3的差异内置函数筛选内置函数map内置的函数sorted新浪数据抓取实时文档测试单元测试函数单元测试一个类day26 综合实战播放音乐设置背景鬼程序协程简介协程传递数据wmv协程编号协程生产者消费者模式office自动化操作wordoffice办公自动化操作exceloffice办公自动化操作outlookoffice办公自动化access开发环境配置访问mdb格式访问accdb格式实现CGI程序显示页面环境变量cgi处理前后端day26down 破解wifi实战扫描wifi扫描网卡区分链接成功或者失败wifi密码爆破工具设计Linux破解简介day27down 飞机大战实战命令行下脱裤创建一个pygame窗体窗体加载背景图片处理消息飞机移动实现基本框架飞机框架飞机销毁双机对战双机对战加载子弹双机与敌机出现发射子弹day27up 数据库实战jython的安装MySQL简介数据库的一般操作MySQL数据类型数据表的创建于删除数据的查询数据的插入数据的删除数据的更新联合查询字段一致数据查询排序排序与分组join与nullmysql用python编程查询数据python数据库增删查改项目简介other 异常与错误综合练习异常与错误的概念作业tryexcept解决异常不出错继续
执行
密码破解工具进攻数据库爆破mysql异常else异常处理的标准公式弹出异常withas类中使用异常继承自定义异常断言密码工具设计三个独立的类密码工具2类链接3类密码工具1类链接3类密码工具分析作业speech 语音识别问题解决语音识别解决None
sqlserver
存储过程
拼接
sql语句
,
执行
报错“列名
无效
”
今天写
存储过程
,遇到一个问题,具体如下:需求是要统计一张报表,这张表的列不固定,因此在
存储过程
里做插入语句的时候,就用到了
sql语句
拼接再
执行
。这里拼接的insert语句是set @sql= 'insert into ##tn(prj) values('+@pzid+')' 如果按照上述语句
执行
就会报错“列名
无效
”;改为 set @sql= 'insert into ##tn(prj) va...
pl/sql developer中用
exec
ute调用
存储过程
弹出‘
无效
的
sql语句
’…该怎么解决
转自:http://www.myexception.cn/oracle-management/267605.html ------解决方案-------------------- 1、在sql的
执行
窗口中只能这样调用"call OUT_TIME(); ",这样
执行
就是把”call OUT_TIME(); “当成一个
sql语句
,而
exec
OUT_TIME();不是一个
sql语句
,是一个
执行
基础和管理
17,377
社区成员
95,127
社区内容
发帖
与我相关
我的任务
基础和管理
Oracle 基础和管理
复制链接
扫一扫
分享
社区描述
Oracle 基础和管理
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章