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 ...
随机推荐
- JavaScript 是世界上最好的语言?
2016年1月中旬,Stack Overflow发起本年度的开发者调查,调查结果于近日公布.本文盘点 JS 开发者应该会关心的部分数据. Stack Overflow 技术排行榜: 在2015年6月, ...
- SCIP读书笔记(1)
这书也算是必修吧,尤其是我这种非科班人员,还是应该抽时间尽量学习一下.大致翻过一遍,习题非常多,尽力吧. ##构造过程抽象 * 为了表述认知,每种语言都提供了三种机制:基本元素:组合方式:抽象方法. ...
- tem
有时间需要整理的东西 1.登录 2.后台框架(管理界面) 3.api详细情况调用 4.具有基础操作的模块 5.session 6.操作权限控制
- css3 文本超出后出现省略号
clip:当内联内容溢出块容器时,将溢出部分裁切掉. ellipsis:当内联内容溢出块容器时,将溢出部分替换为(...). 当块容器 <' overflow '> 为非visible时, ...
- UITableView编写可以添加,删除,移动的物品栏(一)
效果图 : 点击编辑按钮: 点击添加按钮 ...
- 删除svn密码方法
很多时候使用svn,我们需要切换svn账号,但是由于之前的账号已经选择了记住密码,那么我们应该如何删除svn密码来切换新的svn账号呢? 其实很简单,svn账号密码信息保存在电脑某一文件中,我们只要删 ...
- 谷歌的C++智能指针实现
//智能指针基类所有智能指针对象都继承该类class RefCountedBase { public: ; ; protected: virtual ~RefCountedBase(){} }; 智能 ...
- Vim自动补全神器:YouCompleteMe(转)
转自:http://blog.jobbole.com/58978/ 可能会有一段时间写linxu,免不了用vim,留着,找时间实操之 原文出处: marchtea 的博客 第一次听说这个插件还是在偶然 ...
- js上传图片并预览
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...
- 动画特效的原生、jQ和CSS3方法
最近一直在看运动的JS特效,主要看的是原生写法,太麻烦了,最终看到写了个运动的方法,后面可以直接引用,然后发现这个方法和jQ其实差不多了,代码分别如下: 基本的HMTL和CSS <!DOCTYP ...