sqlserver 数据库 join 后面必须加 on吗?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sqlserver 数据库 join 后面必须加 on吗?相关的知识,希望对你有一定的参考价值。
我就是测试了不行了,其他数据库有没有不用加的?
参考技术A 是要加的,但是如果是Inner Join
可以不使用Join
如
Select A.* From A, B Where A.NID = B.NID本回答被提问者采纳
Java的长整型Long/long后面的数字什么情况下必须加L?
[1] 问题的由来
在日常开发中,实体类需要序列化,一般写法如下:
public class User implements java.io.Serializable
private static final long serialVersionUID = 1L;
// 用户id
private Long user_id;
上述代码中,private static final long serialVersionUID = 1L;
,数字1后面为什么要加L
。
要想彻底搞懂这个问题,我们要先理解:
1、Java中整型直接量在没有加后缀的时候默认为int,但是当它被赋值给某个变量(这个变量是short型,int型,byte型中的一种)时,则会自动转化成相对应的类型;
2、Java的4个整数基本类型:byte->short->int->long;
3、向上转型、向下转型;
4、装箱、拆箱;
下面我们分情况讨论,定义长整型时,什么时候应该加L
,什么时候可以不加L
。
[2] 用long定义长整型数字时
long a = 1; // 类型int向上转型为long
long a = 1L; // 类型直接定义为long
long a = 2147483648; // 错误 int的最大表示范围是2147483647
long a = 2147483648L; // 正确 2147483648为长整型
上面四行代码:
1、由于Java默认数字是int类型的,而int向上转型为long是安全的,所以第一句正确执行;
2、数字后面加了l
或L
后,类型变为长整型,第二句自然没问题;
3、int能表示的数字有一定范围,超过这个范围必须加l
或L
才不会出错,所以第三句出错,第四句正确。
【注】由第一行的代码可以联想到,为什么每次定义byte、short、int类型可以直接写,定义long类型要注意加L的情况。
[3] 用Long定义长整型数字时
Long a = 1; // 错误 Long的自动装箱必须要求long类型的数字
Long a = 1L; // 正确 1L是long类型 自动装箱
Long a = new Long(1); // 正确 Long构造器的形参要求long类型的数字,int类型可以向上转型为long类型
Long a = new Long(1L); // 正确 1L是long类型
Long a = new Long(2147483648); // 错误 int的最大表示范围是2147483647,表示错误
Long a = new Long(2147483648L); // 正确 2147483648为长整型
上面六行代码:
1、自动装箱严格要求对应的基本类型要一致,所以第1行错误第2行正确;
2、使用构造器创建Long类型数字时,形参是long类型,int类型可以去向上转型,所以第3、4行正确;
3、使用构造器时,必须注意int不可以超过范围。
[4] 综上可得两种必须加L的情况
1、使用long
和new Long()
定义时,当数字超过int类型的表示范围时必须要在数字后加L
;
2、使用Long
定义时,数字必须要加L
。
以上是关于sqlserver 数据库 join 后面必须加 on吗?的主要内容,如果未能解决你的问题,请参考以下文章
使用left join关联中 on后面的and条件和where后面的条件区别