不得不记录下Oracle的条件语句

本文详细介绍了PL/SQL中的条件语句语法,包括单一语句判断、if-else判断及多重判断,并探讨了如何在PL/SQL中判断变量是否为空的特殊情况。

条件语句语法:

 

 

1、单一语句判断:

if  then
  sql 或 pl/sql
end if;

2、if else 判断:

if  then
  sql 或 pl/sql
else
  sql 或 pl/sql
end if;

3、多重判断:

if  then
  sql 或 pl/sql
elsif then
  sql 或 pl/sql
elsif  then
  sql 或 pl/sql
...
end if;

 

 这里的 elsif 是少了个e,我在编辑器里面打了n遍就是不变色,原来他语法少个e...  无语中。。。

 

 还有pl/sql 判断一个变量是否为空,也比较怪异。这里写下吧。。。

 

 declare 

cc varchar2(10) := '';
begin
  if cc is null then
    dbms_output.put_line('cc is null');
  end if;
  
  if cc = '' then
    dbms_output.put_line('dd is ""');
  end if;
end;

这里输出是:cc is null,这里居然进的是第一个if.不解。。
 

 

declare 
cc varchar2(10) := 's';
begin
  if cc is not null and cc  '' then
    dbms_output.put_line('first if..');
  end if;

  if cc is not null then
    dbms_output.put_line('second if...');
  end if;
end;

这里输出:second if...
 

 

   所以在pl/sql 里,判断变量不为空,用 is not null 就可以了,不要在加 <>  ''

 

 

  原来PL/SQL 里,''和null是否相等跟其数据类型相关。看例子。。

 

  declare

  a char(10) := ''; --定长空字符串
  b varchar(20) := ''; --可变长度空字符串
begin
  if a is null then
    dbms_output.put_line('a is null');
  else
    dbms_output.put_line('a is not null');
  end if;
  if b is null then
    dbms_output.put_line('b is null');
  else
    dbms_output.put_line('b is not null');
  end if;
end;

 

   结果:

 

 

 

 

a is not null
b is null


--结论就是在pl/sql中,如果是定长(char)的空字符串''和null不一样,可变长度(varchar)的空字符串和null是一样的。
 

 

 

 

【博士论文复现】【阻抗建模、验证扫频法】光伏并网逆变器扫频与稳定性分析(包含锁相环电流环)(Simulink仿真实现)内容概要:本文档是一份关于“光伏并网逆变器扫频与稳定性分析”的Simulink仿真实现资源,重点复现博士论文中的阻抗建模与扫频法验证过程,涵盖锁相环和电流环等关键控制环节。通过构建详细的逆变器模型,采用小信号扰动方法进行频域扫描,获取系统输出阻抗特性,并结合奈奎斯特稳定判据分析并网系统的稳定性,帮助深入理解光伏发电系统在弱电网条件下的动态行为与失稳机理。; 适合人群:具备电力电子、自动控制理论基础,熟悉Simulink仿真环境,从事新能源发电、微电网或电力系统稳定性研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①掌握光伏并网逆变器的阻抗建模方法;②学习基于扫频法的系统稳定性分析流程;③复现高水平学术论文中的关键技术环节,支撑科研项目或学位论文工作;④为实际工程中并网逆变器的稳定性问题提供仿真分析手段。; 阅读建议:建议读者结合相关理论教材与原始论文,逐步运行并调试提供的Simulink模型,重点关注锁相环与电流控制器参数对系统阻抗特性的影响,通过改变电网强度等条件观察系统稳定性变化,深化对阻抗分析法的理解与应用能力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值