java 字符串为null 如何判断

Python011

java 字符串为null 如何判断,第1张

定义 String str

判断字符串是否空涉及两个层次:

1、是首先判断字符串变量的引用是否为空,即空对象的概念,用null来判断,可以用if(str==null) 判断 str是否为空;(注意不能用equals(null),在参数为null情况下,返回值永远是false);

2、是在不为空对象的情况下,在判断字符串对象是否为空串,即长度为0.用length()==0。 关键是搞清楚字符串对象为空和空字符串有区别。

拓展内容

Java空字符串与null的区别:

1、类型

null表示的是一个对象的值,而并不是一个字符串。例如声明一个对象的引用,String a = null

""表示的是一个空字符串,也就是说它的长度为0。例如声明一个字符串String str = ""

2、内存分配

String str = null 表示声明一个字符串对象的引用,但指向为null,也就是说还没有指向任何的内存空间;

String str = ""表示声明一个字符串类型的引用,其值为""空字符串,这个str引用指向的是空字符串的内存空间;

在java中变量和引用变量是存在栈中(stack),而对象(new产生的)都是存放在堆中(heap)。

如下:

String str = new String("abc")

参考资料:java官方网站

Java中字符串的常用方法

在众多SQL中,统计型SQL绝对是让人头疼的一类,之所以如此,是因为这种SQL中必然有大量的判读对比。而条件判断函数就是应对这类需求的利器。本文重点总结 CASE WHEN 、 IF 、 IFNULL 三种函数。

Case when语句能在SQL语句中织入判断逻辑,类似于Java中的if else语句。

CASE WHEN语句分为简单函数和条件表达式。

1、简单函数

如果字段值等于预期值,则返回结果1,否则返回结果2。

下面通过一个简单的示例来看一下具体用法。

表score:

场景:在score表中,sex为1表示男性,sex=0表示女性,查询时转换成汉字显示。

SQL语句:

结果:

2、条件表达式

CASE的简单函数使用简便,但无法应对较为复杂的场景,这就需要用到条件表达式了,其语法结构如下:

解释一下,语句中的condition是条件判断,如果该判断结果为true,那么CASE语句将返回result,否则返回result2,如果没有ELSE,则返回null。CASE与END之间可以有多个WHEN…THEN…ELSE语句。END表示CASE语句结束。

场景:score 大于等于90为优秀,80-90为良好,60-80为及格,小于60为不及格,用SQL语句统计出每个学生的成绩级别。

SQL:

结果:

3、综合使用

CASE WHEN 和 聚合函数综合使用,能实现更加复杂的统计功能。

先看第1个场景

在下表 score (sex=1为男,sex=0为女)中,统计有多少个男生和女生以及男女生及格的各有多少个。

SQL:

结果:

再看第2个场景

将上面的score表转换为下面形式:

SQL:

结果如下:

IF函数也能通过判断条件来返回特定值,它的语法如下:

expr是一个条件表达式,如果结果为true,则返回result_true,否则返回result_false。

用一个示例演示,还是表score:

使用IF函数:

可以看出,在一些场景中, IF 函数和 CASE WHEN 是有同样效果的,前者相对简单,后者能应对更复杂的判断。

另外,IF函数还可以和聚合函数结合,例如查询班级男生女生分别有多少人:

在Java程序中调用sql语句时,如果返回结果是 null ,是非常容易引发一些意外情况的。

因此,我们希望在SQL中做一些处理,如果查询结果是 null ,就转换为特定的值,这就要用到Mysql中 IFNULL 函数。

首先SQL一般写法是这样的:

使用 IFNULL 改写一下:

但使用 IFNULL 语句,如果 where 条件中的 name 值是不存在的,那么仍将返回 null ,例如:

这时候,需要改写成下面的形式:

在实际应用中,如果你确定 where 条件的值一定存在,使用前者就可以了,否则要用后者。

IFNULL 函数也可以结合聚合使用,例如:

其他, AVG 、 COUNT 等用同样方式处理,而且,无论 where 条件存在不存在,结果都是会返回0的。

END

引用链接:blog.csdn.net/mu_wind/article/details/93976316