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 关于变量定义的问题的更多相关文章

  1. pl/sql基础知识—定义并使用变量

    n  介绍 在编写pl/sql程序是,可以定义变量和常量:在pl/sql程序中包括有: ①标量类型(scalar) ②复合类型(composite) ③参照类型(reference) ④lob(lar ...

  2. PL/SQL之--变量

    一.PL/SQL 简介 PL/SQL也是一种程序语言,叫做过程化SQL语言(Procedural Language/SQL).PL/SQL是oracle对sql语句的一种扩展,在普通SQL语句的使用上 ...

  3. PL/SQL编程—变量

    SQL> declare c_tax_rate ,):=0.03; v_name ); v_passwd ); v_sale ,); v_tax_sale ,); begin select na ...

  4. 基于oracle 的PL/SQL编程 -变量使用

    1. 需要开启的服务:  本机安装的oracle ,默认是开机启动服务的,开机时间太慢,关闭了,需要手动打开: OracleDBConsoleorcl OracleOraDb10g_home1iSQL ...

  5. sql语句变量定义和样例

    变量和与常量 1.定义和使用局部变量说明:局部变量是用户可自定义的变量,它的作用范围仅在程序内部.局部变量的名称是用户自定义的,命名的局部变量名要符合SQL Server 2000标识符命名规则,必须 ...

  6. SQL Server 变量定义

    declare @id intdeclare @name char(10) --注意:char(10)为10位,要是位数小了会让数据出错set @id=1 set @name='sssss'selec ...

  7. SQL 将变量定义为Table类型

    ),a2 ,),a4 DATETIME,a5 UNIQUEIDENTIFIER) ,11.22,GETDATE(),NEWID()) ,11.22,GETDATE(),NEWID()) ,11.22, ...

  8. PL/SQL编程--变量声明及赋值

    declare v_price ,);--单价 v_usenum number;--水费字数 v_usenum2 number;--使用吨数 begin v_price:=2.45;--每吨单价 v_ ...

  9. 二十四、oracle pl/sql 变量

    一.变量介绍在编写pl/sql程序时,可以定义变量和常量:在pl/sql程序中包括有:1).标量类型(scalar)2).复合类型(composite) --用于操作单条记录3).参照类型(refer ...

随机推荐

  1. Cracking the coding interview-String

    关于字符串 问题描述:一般这类程序设计的题目较简单,通过设计字符串的反转,寻找子串,以及字符串的拼接.删除操作等问题. 问题 实现一个算法来判断一个字符串中的字符是否唯一(即没有重复)? 设计算法并写 ...

  2. MAC OS X API知识摘抄

    本文为信息为网上各个地方收集整理Carbon和Cocoa,Toolbox,POSIX,JAVA并列成为Mac OS X五个主要的API.与Cocoa相较之下,Carbon是非物件导向(Procedur ...

  3. WPF--ComboBox数据绑定

    WPF--ComboBox数据绑定 0-在ComboBox中显示图片: <ComboBox Height="33" HorizontalAlignment="Rig ...

  4. quartz简单实现

    quartz介绍 在我们的项目中,经常会遇到某个任务需要在特定的时间点执行,这个时间点可能是每天的某分某秒,可能是一周的指定某个星期某个时间等:quartz就是实现这样一个复杂任务调度逻辑的框架. 官 ...

  5. javascript 之闭包-理解不了来找我

    1,闭包是什么 (百度百科定义)--闭包是可以包含自由(未绑定到特定对象)变量的代码块:这些变量不是在这个代码块内或者任何全局上下文中定义的,而是在定义代码块的环境中定义(局部变 量).“闭包” 一词 ...

  6. Spring3 + Spring MVC+ Mybatis 3+Mysql 项目整合

    项目环境背景: 操作系统:win7 JDK:1.7 相关依赖包,截图如下:

  7. 【转载】介绍“Razor”— ASP.NET的一个新视图引擎

    最近在做一个项目,用的MVC razor 视图,因为之前没用这个视图做过,于是查阅文档资料,共享一下. https://msdn.microsoft.com/zh-cn/ff849693 内容主要是讲 ...

  8. 召回率与准确率[ZZ]

    最近一直在做相关推荐方面的研究与应用工作,召回率与准确率这两个概念偶尔会遇到,知道意思,但是有时候要很清晰地向同学介绍则有点转不过弯来. 召回率和准确率是数据挖掘中预测.互联网中的搜索引擎等经常涉及的 ...

  9. Windows Phone 之播放视频

    在Windows Phone 7中播放视频有两种方式, (1)使用MediaElement 控件来播放:用MediaElement 控件来播放视频比较灵活,你需要自己去实现播放暂停进度条等等的功能,播 ...

  10. Linux 特殊权限位

    特殊权限位 LINUX 基本权限有9位但是还有三位特殊权限. suid s(有x权限) S(没有x权限) 4 在用户权限的第三位 sgid s(有x权限) S(没有x权限) 2 在用户组权限的第三位 ...