在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

数据库中的记录类型判断非空的办法是什么

110次阅读
没有评论

共计 4471 个字符,预计需要花费 12 分钟才能阅读完成。

本篇内容主要讲解“数据库中的记录类型判断非空的办法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让丸趣 TV 小编来带大家学习“数据库中的记录类型判断非空的办法是什么”吧!

我创建了如下的包:

CREATE OR REPLACE PACKAGE plch_pkg
 TYPE info_rt IS RECORD
 ( name VARCHAR2 (100)
 , dob DATE
 );
 TYPE info_plus_rt IS RECORD
 ( group_name VARCHAR2 (100)
 , group_total NUMBER
 , more_info info_rt
 );
/

哪些选项在执行后将会显示 NOT NULL ?

(A)

DECLARE
 l_my_record plch_pkg.info_plus_rt;
BEGIN
 l_my_record.group_name :=  Oracle Bloggers 
 l_my_record.more_info.dob := SYSDATE;
 IF l_my_record IS NOT NULL
 THEN
 DBMS_OUTPUT.put_line ( NOT NULL 
 ELSE
 DBMS_OUTPUT.put_line ( NULL 
 END IF;
/
SQL  DECLARE
 2 l_my_record plch_pkg.info_plus_rt;
 3 BEGIN
 4 l_my_record.group_name :=  Oracle Bloggers 
 5 l_my_record.more_info.dob := SYSDATE;
 6 
 7 IF l_my_record IS NOT NULL
 8 THEN
 9 DBMS_OUTPUT.put_line ( NOT NULL 
 10 ELSE
 11 DBMS_OUTPUT.put_line ( NULL 
 12 END IF;
 13 END;
 14 /
DECLARE
 l_my_record plch_pkg.info_plus_rt;
BEGIN
 l_my_record.group_name :=  Oracle Bloggers 
 l_my_record.more_info.dob := SYSDATE;
 IF l_my_record IS NOT NULL
 THEN
 DBMS_OUTPUT.put_line ( NOT NULL 
 ELSE
 DBMS_OUTPUT.put_line ( NULL 
 END IF;
ORA-06550:  第  7  行,  第  7  列: 
PLS-00306:  调用   IS NOT NULL   时参数个数或类型错误
ORA-06550:  第  7  行,  第  4  列: 
PL/SQL: Statement ignored
SQL

(B)

DECLARE
 l_my_record plch_pkg.info_plus_rt;
BEGIN
 l_my_record.group_name :=  Oracle Bloggers 
 l_my_record.more_info.dob := SYSDATE;
 IF l_my_record.group_name IS NOT NULL
 OR l_my_record.group_total IS NOT NULL
 OR l_my_record.more_info IS NOT NULL
 THEN
 DBMS_OUTPUT.put_line ( NOT NULL 
 ELSE
 DBMS_OUTPUT.put_line ( NULL 
 END IF;
/
SQL  DECLARE
 2 l_my_record plch_pkg.info_plus_rt;
 3 BEGIN
 4 l_my_record.group_name :=  Oracle Bloggers 
 5 l_my_record.more_info.dob := SYSDATE;
 6 
 7 IF l_my_record.group_name IS NOT NULL
 8 OR l_my_record.group_total IS NOT NULL
 9 OR l_my_record.more_info IS NOT NULL
 10 THEN
 11 DBMS_OUTPUT.put_line ( NOT NULL 
 12 ELSE
 13 DBMS_OUTPUT.put_line ( NULL 
 14 END IF;
 15 END;
 16 /
DECLARE
 l_my_record plch_pkg.info_plus_rt;
BEGIN
 l_my_record.group_name :=  Oracle Bloggers 
 l_my_record.more_info.dob := SYSDATE;
 IF l_my_record.group_name IS NOT NULL
 OR l_my_record.group_total IS NOT NULL
 OR l_my_record.more_info IS NOT NULL
 THEN
 DBMS_OUTPUT.put_line ( NOT NULL 
 ELSE
 DBMS_OUTPUT.put_line ( NULL 
 END IF;
ORA-06550:  第  9  行,  第  10  列: 
PLS-00306:  调用   IS NOT NULL   时参数个数或类型错误
ORA-06550:  第  7  行,  第  4  列: 
PL/SQL: Statement ignored
SQL

(C)

DECLARE
 l_my_record plch_pkg.info_plus_rt;
BEGIN
 l_my_record.group_name :=  Oracle Bloggers 
 l_my_record.more_info.dob := SYSDATE;
 IF l_my_record.group_name IS NOT NULL
 OR l_my_record.group_total IS NOT NULL
 OR l_my_record.more_info.name IS NOT NULL
 OR l_my_record.more_info.dob IS NOT NULL
 THEN
 DBMS_OUTPUT.put_line ( NOT NULL 
 ELSE
 DBMS_OUTPUT.put_line ( NULL 
 END IF;
/
SQL  DECLARE
 2 l_my_record plch_pkg.info_plus_rt;
 3 BEGIN
 4 l_my_record.group_name :=  Oracle Bloggers 
 5 l_my_record.more_info.dob := SYSDATE;
 6 
 7 IF l_my_record.group_name IS NOT NULL
 8 OR l_my_record.group_total IS NOT NULL
 9 OR l_my_record.more_info.name IS NOT NULL
 10 OR l_my_record.more_info.dob IS NOT NULL
 11 THEN
 12 DBMS_OUTPUT.put_line ( NOT NULL 
 13 ELSE
 14 DBMS_OUTPUT.put_line ( NULL 
 15 END IF;
 16 END;
 17 /
NOT NULL
PL/SQL procedure successfully completed
SQL

(D)

CREATE OR REPLACE FUNCTION plch_not_null_rec (rec_in IN plch_pkg.info_plus_rt)
 RETURN BOOLEAN
BEGIN
 RETURN rec_in.group_name IS NOT NULL
 OR rec_in.group_total IS NOT NULL
 OR rec_in.more_info.name IS NOT NULL
 OR rec_in.more_info.dob IS NOT NULL;
DECLARE
 l_my_record plch_pkg.info_plus_rt;
BEGIN
 l_my_record.group_name :=  Oracle Bloggers 
 l_my_record.more_info.dob := SYSDATE;
 IF plch_not_null_rec (l_my_record)
 THEN
 DBMS_OUTPUT.put_line ( NOT NULL 
 ELSE
 DBMS_OUTPUT.put_line ( NULL 
 END IF;
/
SQL  CREATE OR REPLACE FUNCTION plch_not_null_rec (rec_in IN plch_pkg.info_plus_rt)
 2 RETURN BOOLEAN
 3 IS
 4 BEGIN
 5 RETURN rec_in.group_name IS NOT NULL
 6 OR rec_in.group_total IS NOT NULL
 7 OR rec_in.more_info.name IS NOT NULL
 8 OR rec_in.more_info.dob IS NOT NULL;
 9 END;
 10 /
Function created
SQL  DECLARE
 2 l_my_record plch_pkg.info_plus_rt;
 3 BEGIN
 4 l_my_record.group_name :=  Oracle Bloggers 
 5 l_my_record.more_info.dob := SYSDATE;
 6 
 7 IF plch_not_null_rec (l_my_record)
 8 THEN
 9 DBMS_OUTPUT.put_line ( NOT NULL 
 10 ELSE
 11 DBMS_OUTPUT.put_line ( NULL 
 12 END IF;
 13 END;
 14 /
NOT NULL
PL/SQL procedure successfully completed
SQL
 答案  CD
对记录类型不能使用 IS NOT NULL 判断,否则会出现:PLS-00306: wrong number or types of arguments in call to  IS NOT NULL 
这导致 AB 出现异常。Steven Feuerstein 建议你采用 D 的做法以便于重用代码。

到此,相信大家对“数据库中的记录类型判断非空的办法是什么”有了更深的了解,不妨来实际操作一番吧!这里是丸趣 TV 网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-24发表,共计4471字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 人妻中文无码久热丝袜 | 亚洲处破女av日韩精品 | 男女扒开双腿猛进入免费看污 | 热er99久久6国产精品免费 | 一区二区国产在线播放 | 欧美精品亚洲精品日韩专区 | 免费看成人国产一区二区三区 | 日本免费人成视频在线观看 | 99久久99久久精品免费看子伦 | 久久夜色精品国产亚洲av动态图 | 少妇做爰又色又紧夜视频 | 久久婷婷五月国产色综合 | 北条麻妃二区 | 午夜色大片在线观看 | 欧美一区二区三区国产精品 | 夜夜爽一区二区三区精品 | 人人人妻人人澡人人爽欧美一区 | 精品熟女碰碰人人a久久 | 日本一区午夜艳熟免费 | 一级黄色片在线 | 韩国免费α一级一片 | 久久久国产99久久国产首页 | 日韩不卡一区二区 | 自偷自拍亚洲综合精品 | 欧美综合在线播放 | 亚洲黄色一级毛片 | 日本一级毛片在线观看 | 亚洲福利视频网站 | 欧美国产精品va在线观看 | 米奇影音777第四色 米奇影院77777在线观看 | 国产三级在线播放线 | 2020久久精品国产免费 | 丁香花在线影院观看在线播放 | 国产欧美va欧美va在线 | 亚洲乱色熟女一区二区三区丝袜 | 操丝袜美女视频 | 久久精品国产99国产精品 | 日韩欧美在线观看成人 | 日本亚洲一区二区三区 | 日本丶国产丶欧美色综合 | 丰满人妻被中出中文字幕 |