pl/sql 关于变量定义的问题
1.
create or replace procedure test_prc(p_data_dt in date) IS
e_name emp.ename%type;
begin
select ename into e_name
from emp where hiredate =p_data_dt;
DBMS_OUTPUT.PUT_LINE(e_name || '---' ||p_data_dt);
end;
此时输入的是日期型的参数:
SQL> call test_prc(date'1980-12-17');
SMITH---17-DEC-80
Call completed.
---------------------------------------------------------------------
2.
create or replace procedure test_prc(p_data_dt in VARCHAR) IS
e_name emp.ename%type;
v_data_dt DATE :=to_date(p_data_dt,'YYYY-MM-DD');
begin
select ename into e_name
from emp where hiredate =v_data_dt;
DBMS_OUTPUT.PUT_LINE(e_name || '---' ||v_data_dt);
end;
SQL> call test_prc('1980-12-17');
SMITH---17-DEC-80
Call completed.
-------------------------------------------------------------------
3.
create or replace procedure test_prc(p_data_dt in VARCHAR) IS
e_name emp.ename%type;
begin
select ename into e_name
from emp where hiredate =to_date(P_data_dt,'yyyy-mm-dd');
DBMS_OUTPUT.PUT_LINE(e_name || '---' ||P_data_dt);
end;
SQL> exec test_prc('1980-12-17');
SMITH---1980-12-17
PL/SQL procedure successfully completed.
4.
create or replace procedure test_prc(p_data_dt in VARCHAR) IS
org dwm.debit_card_org.card_open_org%type;
begin
select dwm.debit_card_org.card_open_org into org
from dwm.debit_card_org where data_dt =to_date(P_data_dt,'yyyy-mm-dd')
and rownum<2;
DBMS_OUTPUT.PUT_LINE(org || '---' ||P_data_dt);
end;
exec test_prc(2013-01-01);
SQL> exec test_prc(2013-01-01);
BEGIN test_prc(2013-01-01); END;
*
ERROR at line 1:
ORA-01840: input value not long enough for date format
ORA-06512: at "DWM.TEST_PRC", line 4
ORA-06512: at line 1
exec test_prc('2013-01-01');
---------------------------------------------------------------------------------------
5.
create or replace procedure test_prc(p_data_dt VARCHAR2) IS
org dwm.debit_card_org.card_open_org%type;
begin
select dwm.debit_card_org.card_open_org into org
from dwm.debit_card_org where data_dt =to_date(P_data_dt,'yyyy-mm-dd')
and rownum<2;
DBMS_OUTPUT.PUT_LINE(org || '---' ||P_data_dt);
end;
----------------------------------------------------------------
6.
create or replace procedure test_prc(p_data_dt in NUMBER) IS
e_name emp.ename%type;
v_data_dt DATE :=to_date(p_data_dt,'YYYY-MM-DD');
begin
select ename into e_name
from emp where hiredate =v_data_dt;
DBMS_OUTPUT.PUT_LINE(e_name || '---' ||v_data_dt);
end;
SQL> exec test_prc(19801217);
PL/SQL procedure successfully completed.
SQL> set serveroutput
SP2-0265: serveroutput must be set ON or OFF
SQL> set serveroutput on
SQL> exec test_prc(19801217);
SMITH---17-DEC-80
PL/SQL procedure successfully completed.
7.
SQL> create table test_2(id int,data_dt DATE);
Table created.
SQL> insert into test_2 values(1,to_date(20130101,'yyyymmdd'));
1 row created.
SQL> commit;
Commit complete.
SQL> select * from test_2;
ID DATA_DT
---------- ---------
1 01-JAN-13
create or replace procedure test_prc(p_data_dt in VARCHAR) IS
ID test_2.ID%type;
begin
select ID into ID
from test_2 where data_dt =to_date(p_data_dt,'yyyymmdd');
DBMS_OUTPUT.PUT_LINE(ID || '---' ||p_data_dt);
end;
SQL> exec test_prc(20130101);
1---20130101
PL/SQL procedure successfully completed.
SQL> exec test_prc('20130101');
1---20130101
PL/SQL procedure successfully completed.
SQL> exec test_prc(2013-01-01);
BEGIN test_prc(2013-01-01); END;
*
ERROR at line 1:
ORA-01840: input value not long enough for date format
ORA-06512: at "SCOTT.TEST_PRC", line 5
ORA-06512: at line 1
SQL> exec test_prc('2013-01-01');
BEGIN test_prc('2013-01-01'); END;
*
ERROR at line 1:
ORA-01843: not a valid month
ORA-06512: at "SCOTT.TEST_PRC", line 5
ORA-06512: at line 1
8.
create or replace procedure test_prc(p_data_dt in VARCHAR) IS
ID test_2.ID%type;
begin
select ID into ID
from test_2 where data_dt =to_date(p_data_dt,'yyyy-mm-dd');
DBMS_OUTPUT.PUT_LINE(ID || '---' ||p_data_dt);
end;
SQL> exec test_prc(2013-01-01);
BEGIN test_prc(2013-01-01); END;
*
ERROR at line 1:
ORA-01840: input value not long enough for date format
ORA-06512: at "SCOTT.TEST_PRC", line 5
ORA-06512: at line 1
SQL> exec test_prc('2013-01-01');
1---2013-01-01
PL/SQL procedure successfully completed.
9.
create or replace procedure test_prc(p_data_dt in VARCHAR) IS
ID test_2.ID%type;
begin
/*select ID into ID
from test_2 where data_dt =to_date(p_data_dt,'yyyy-mm-dd'); */
DBMS_OUTPUT.PUT_LINE(ID || '---' ||p_data_dt);
end;
SQL> exec test_prc('2013-01-01');
---2013-01-01
PL/SQL procedure successfully completed.
SQL> exec test_prc(2013-01-01);
---2011
PL/SQL procedure successfully completed.
但是在PL/SQL工具里可以直接选择字符窜,就不会出现这种问题,如下图:
pl/sql 关于变量定义的问题的更多相关文章
- pl/sql基础知识—定义并使用变量
n 介绍 在编写pl/sql程序是,可以定义变量和常量:在pl/sql程序中包括有: ①标量类型(scalar) ②复合类型(composite) ③参照类型(reference) ④lob(lar ...
- PL/SQL之--变量
一.PL/SQL 简介 PL/SQL也是一种程序语言,叫做过程化SQL语言(Procedural Language/SQL).PL/SQL是oracle对sql语句的一种扩展,在普通SQL语句的使用上 ...
- PL/SQL编程—变量
SQL> declare c_tax_rate ,):=0.03; v_name ); v_passwd ); v_sale ,); v_tax_sale ,); begin select na ...
- 基于oracle 的PL/SQL编程 -变量使用
1. 需要开启的服务: 本机安装的oracle ,默认是开机启动服务的,开机时间太慢,关闭了,需要手动打开: OracleDBConsoleorcl OracleOraDb10g_home1iSQL ...
- sql语句变量定义和样例
变量和与常量 1.定义和使用局部变量说明:局部变量是用户可自定义的变量,它的作用范围仅在程序内部.局部变量的名称是用户自定义的,命名的局部变量名要符合SQL Server 2000标识符命名规则,必须 ...
- SQL Server 变量定义
declare @id intdeclare @name char(10) --注意:char(10)为10位,要是位数小了会让数据出错set @id=1 set @name='sssss'selec ...
- SQL 将变量定义为Table类型
),a2 ,),a4 DATETIME,a5 UNIQUEIDENTIFIER) ,11.22,GETDATE(),NEWID()) ,11.22,GETDATE(),NEWID()) ,11.22, ...
- PL/SQL编程--变量声明及赋值
declare v_price ,);--单价 v_usenum number;--水费字数 v_usenum2 number;--使用吨数 begin v_price:=2.45;--每吨单价 v_ ...
- 二十四、oracle pl/sql 变量
一.变量介绍在编写pl/sql程序时,可以定义变量和常量:在pl/sql程序中包括有:1).标量类型(scalar)2).复合类型(composite) --用于操作单条记录3).参照类型(refer ...
随机推荐
- "ORA-00942: 表或视图不存在 "的原因和解决方法
"ORA-00942: 表或视图不存在 "的原因和解决方法 采用Oracle数据库,使用Powerdesigner设计,生成Sql文件导入后查询出现“ORA-00942: 表或 ...
- docker build lnmp(未完成。。。)
docker pull centos # 拉取镜像到本地 docker run -i -t -p 8000:80 --name=centosDev centos cat /etc/redhat-rel ...
- PHP-popen() 函数打开进程文件指针
待更新 版权声明:本文为博主原创文章,未经博主允许不得转载.
- [上传下载] C# ImageUpload图片上传类教程与源码下载 (转载)
点击下载 ImageUpload.zip 功能如下图片1.设置属性后上传图片,用法如下 /// <summary> /// 图片上传类 /// </summary> //--- ...
- 再次回首 TCP Socket服务器编程
转载:http://www.cnblogs.com/zc22/archive/2010/06/27/1766007.html ------------------ 前言 --------------- ...
- 新安装 wampserver 出现 You don't have permission to access / on this server. 或者访问数据库出现You don't have permission to access /phpmyadmin/ on this server.(解决方法)转
本地搭建wamp,输入http://127.0.0.1访问正常,当输入http://localhost/,apache出现You don't have permission to access/on ...
- 【html】【4】html事件集合
必看参考: http://www.runoob.com/tags/ref-eventattributes.html http://www.cnblogs.com/jiangchongwei/archi ...
- pc110301QWERTYU
水题一道,SOLVED只是次数的问题.map一下,就是很easy啦. #include<iostream> #include<cstdio> #include<cstri ...
- eclipse/ggts/myeclipse清除SVN用户名和密码
很多时候我们在使用eclipse/myeclipse/ggts这些开发工具进行开发的时候会有多个项目存在,不同的项目又存放在不同的svn下,需要进行svn之间的切换,如果你在创建资源库位置的时候保存了 ...
- 序列化魔术函数__sleep()和反序列化魔术函数__wakeup()
1.string serialize ( mixed $value )— 产生一个可存储的值的表示 serialize() 返回字符串,此字符串包含了表示 value 的字节流,可以存储于任何地方. ...