数据库常见笔试、面试题总结

1.多表连接查询

参考:http://blog.csdn.net/suneqing/article/details/18224753

数据库中多表的连接分为以下几种:

表a

id name
1 sun
3 zhang
5 zhao
表b
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
内连接:join或者inner join ,结果集中不包括两个表之间没有匹配的行,通俗点说,将那些带有null值的行去掉。
a.id name b.id score
1 sun 1 90
3 zhang 3 70
交叉连接:cross join ,结果集中包含了第一个表的行数乘以第二个表的行数等于笛卡尔结果集的大小。通俗点说就是第一个表中的每一行与另一个表中的每一行按照从上到下的顺序依次的连接。

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

2.Java中数据库连接步骤

①导入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的成员方法

3.数据库范式

目前关系数据库有六种范式:第一范式(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

你可能感兴趣的:(数据库,面试)