参考:http://blog.csdn.net/suneqing/article/details/18224753
数据库中多表的连接分为以下几种:
表a
id | name |
1 | sun |
3 | zhang |
5 | zhao |
id | score |
1 | 90 |
3 | 70 |
4 | 80 |
左连接:left join ,结果集中包括了left join子句中左表的所有行,如果左表中的某行在右表中没有匹配,那么对应的右表的行为空值null。
a.id | name | b.id | score |
1 | sun | 1 | 90 |
3 | zhang | 3 | 70 |
5 | zhao | null | null |
右连接:right join ,结果集中包括了right join子句中右表的所有行,如果右表中的某行在左表中没有匹配,那么对应的左表的行为空值null。
a.id | name | b.id | score |
1 | sun | 1 | 90 |
3 | zhang | 3 | 70 |
null | null | 4 | 80 |
完整外部连接:full join ,结果集中包括了两个表的所有行,如果一个表中的某行在另一个表中没有匹配,那么对应的行为空值null。
a.id | name | b.id | score |
1 | sun | 1 | 90 |
3 | zhang | 3 | 70 |
5 | zhao | null | null |
null | null | 4 | 80 |
a.id | name | b.id | score |
1 | sun | 1 | 90 |
3 | zhang | 3 | 70 |
a.id | name | b.id | score |
1 | sun | 1 | 90 |
3 | zhang | 1 | 90 |
5 | zhao | 1 | 90 |
1 | sun | 3 | 70 |
3 | zhang | 3 | 70 |
5 | zhao | 3 | 70 |
1 | sun | 4 | 80 |
3 | zhang | 4 | 80 |
5 | zhao | 4 | 80 |
①导入jar包,并加载驱动。
②配置连接属性,包括url、用户名、密码等。
③连接查询等。常用类包括:DriverManager、Connection、Statement、ResultSet。
实例分析:
package db_connector;
import java.sql.*;
public class MainDbConnect {
public static void main(String[] args) {
String driver = "com.mysql.jdbc.Driver";
String url = "jdbc:mysql://127.0.0.1:3306/test";
String user = "root";
String password = "mysql";
try {
//Class.forName(*)要求JVM查找并加载指定类或返回指定类而非类对象
Class.forName(driver);
/*
* 建立连接,配置地址、用户名、密码等。
* Connection与特定数据库的连接(会话)。在连接上下文中执行SQL语句并返回结果。
*/
Connection conn = DriverManager.getConnection(url, user, password);
if(conn.isClosed()==false){
System.out.println("数据库连接正常");
}else{
System.out.println("数据库连接失败");
}
/*
* 用于执行静态 SQL 语句并返回它所生成结果的对象。
* Connection、Statement、ResultSet均为接口,等号后方法返回相应接口实现类的一个类对象,方法在加载的驱动的jar包中实现。
*/
Statement statement = conn.createStatement();
String sql = "select * from a right join b on a.id = b.id";
ResultSet rs = statement.executeQuery(sql);
while(rs.next()){
System.out.println(rs.getString("id") + "\t" + rs.getString("name"));
}
rs.close();
conn.close();
} catch (ClassNotFoundException e) {
System.out.println("找不到驱动器!");
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
}
备注:
①new()与类名.newInstance()均可实例化对象;二者不同之处在于:
a:前者构造方法更多,强类型,高效;
b:后者只能调用无参构造方法,弱类型,低效;
②加载数据库驱动时使用class.forName(*);而非Class.forName(*).newInstance()的原因;
Java里面任何class都要加载在虚拟机上才能运行,而静态代码是和class绑定的,class加载成功就表示执行了你的静态代码了。而在JDBC中明确要求Driver类必须向DriverManager注册自己,在com.mysql.jdbc.Driver中有注册的静态代码,而Class.forName()的作用就是要求JVM查找并加载指定的类。所以不用再实例化调用某些方法。
java.sql.DriverManager.registerDriver(new Driver());
③接口中方法均为static方法,成员变量默认为public static final必须初始化且不可更改。
抽象类中可以有非abstract的成员方法
目前关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、巴斯-科德范式(BCNF)、第四范式(4NF)和第五范式(5NF)。
越高的范式数据库冗余越小,减少数据库中数据冗余的过程。
1NF:数据库中的每一列都是不可分割的原子数据项,而不能是集合、数组、记录等非原子数据项。即实体中的某个属性有多个值时,必须拆分为不同的属性。简而言之,第一范式就是无重复的域。
数据库表中的字段都是单一属性的,不可再分。这个单一属性由基本类型构成,包括整型、实数、字符型、逻辑型、日期型等。在当前的任何关系数据库管理系统(DBMS)中,傻瓜也不可能做出不符合第一范式的数据库,因为这些DBMS不允许你把数据库表的一列再分成二列或多列。因此,你想在现有的DBMS中设计出不符合第一范式的数据库都是不可能的。
2NF:在1NF的基础上,非码属性必须完全依赖于候选码(在1NF基础上消除非主属性对主码的部分函数依赖)。选取一个能区分每个实体的属性或属性组,作为实体的唯一标识。第二范式(2NF)要求实体的属性完全依赖于主关键字。所谓完全依赖是指不能存在仅依赖主关键字一部分的属性。
3NF:在1NF基础上,任何非主属性不依赖于其它非主属性(在2NF基础上消除传递依赖)。第三范式(3NF)是第二范式(2NF)的一个子集,即满足第三范式(3NF)必须满足第二范式(2NF)。简而言之,第三范式(3NF)要求一个关系中不包含已在其它关系已包含的非主关键字信息。例如,存在一个部门信息表,其中每个部门有部门编号(dept_id)、部门名称、部门简介等信息。那么在员工信息表中列出部门编号后就不能再将部门名称、部门简介等与部门有关的信息再加入员工信息表中。如果不存在部门信息表,则根据第三范式(3NF)也应该构建它,否则就会有大量的数据冗余。简而言之,第三范式就是属性不依赖于其它非主属性,也就是在满足2NF的基础上,任何非主属性不得传递依赖于主属性。
传递依赖:(学号)->(系别)->(系办地点、系办电话)
BCNF:在1NF基础上,任何非主属性不能对主键子集依赖(在3NF基础上消除对主码子集的依赖)。
备注:
1NF基本都满足;2NF由依赖关系划分表,确定主键,消除部分函数依赖;3NF消除传递依赖,进一步划分表;
参考:http://baike.baidu.com/link?url=qmwLOM5bJ7A1BaY9EEBvcJ1QLe9guxGCudRQ_V4-rpWyb6AY1AWzU8W0BF_TKiJUDo7XgtU_LpfXD0xKLii4IBpbs5N85aehrWOaYj6tpHUwLh0mMUhAJYI84qzGUxclJwDX1ZtB7AE3BiMAa40Iu_#3_2