数据库三范式是什么?
第一范式(1NF):字段具有原子性,不可再分。所有关系型数据库系统都满足第一范式) 数据库表中的字段都是单一属性的,不可再分。例如,姓名字段,其中的姓和名必须作为一 个整体,无法区分哪部分是姓,哪部分是名,如果要区分出姓和名,必须设计成两个独立的 字段。
第二范式(2NF):第二范式(2NF)是在第一范式(1NF)的基础上建立起来的,即满足 第二范式(2NF)必须先满足第一范式(1NF)。要求数据库表中的每个实例或行必须可以 被惟一地区分。通常需要为表加上一个列,以存储各个实例的惟一标识。这个惟一属性列被 称为主关键字或主键。第二范式(2NF)要求实体的属性完全依赖于主关键字。所谓完全依 赖是指不能存在仅依赖主关键字一部分的属性,如果存在,那么这个属性和主关键字的这一 部分应该分离出来形成一个新的实体,新实体与原实体之间是一对多的关系。为实现区分通 常需要为表加上一个列,以存储各个实例的惟一标识。简而言之,第二范式就是非主属性非 部分依赖于主关键字。
第三范式的要求如下:满足第三范式(3NF)必须先满足第二范式(2NF)。简而言之,第三范式(3NF)要求一个数据库表中不包含已在其它表中已包含的非主关键字信息。所以 第三范式具有如下特征:
1,每一列只有一个值 。
2,每一行都能区分。
3,每一个表都不包含其他表已经包含 的非主关键字信息。例如,帖子表中只能出现发帖人的 id,而不能出现发帖人的 id,还同时出现发帖人姓名, 否则,只要出现同一发帖人 id 的所有记录,它们中的姓名部分都必须严格保持一致,这就 是数据冗余。
说出一些数据库优化方面的经验?
用 PreparedStatement 一般来说比 Statement 性能高:一个 sql 发给服务器执行,步骤:语法 检查、语义分析, 编译,缓存
“inertintouservalues(1,1,1)”->二进制
“inertintouservalues(2,2,2)”->二进制
“inertintouservalues(?,?,?)”->二进制
有外键约束会影响插入和删除性能,如果程序能够保证数据的完整性,那在设计数据库时就 去掉外键。(比喻:就好比免检产品,就是为了提高效率,充分相信产品的制造商) (对于 hibernate 来说,就应该有一个变化:empleyee->Deptment 对象,现在设计时就成了 employee_>deptid)
union 和 unionall 有什么不同?
UNION 在进行表链接后会筛选掉重复的记录,所以在表链接后会对所产生的结果集进 行排序运算,删除重复的记录再返回结果。实际大部分应用中是不会产生重复的记录,最常 见的是过程表与历史表 UNION。而 UNIONALL 只是简单的将两个结果合并后就返回。这样,如果返回的两个结果集中有 重复的数据,那么返回的结果集就会包含重复的数据了。从效率上说,UNIONALL 要比 UNION 快很多,所以,如果可以确认合并的两个结果集 中不包含重复的数据的话,那么就使用 UNIONALL。
分页语句
取出 sql 表中第 31 到 40 的记录(以自动增长 ID 为主键)
sql server 方案 1: select top 10 * from t where id not in(select top 30 id from t order by id)ordeby id sql server 方案 2: select top 10 * from t where id in(select top 40 id fromt order by id) order by id desc mysql 方案:select * from t order by id limit 30,10 oracle 方案:select * from(select rownum r,*from t where r<=40)where r >30
所有部门之间的比赛组合
一个叫 department 的表,里面只有一个字段 name,一共有 4 条纪录,分别是 a,b,c,d,对应四个 球对,现在四个球对进行比赛,用一条 sql 语句显示所有可能的比赛组合.
select a.name,b.name from team a,team b wherea.name< b.name
Class.forName 的作用?为什么要用?
按参数中指定的字符串形式的类名去搜索并加载相应的类,如果该类字节码已经被加载 过,则返回代表该字节码的 Class 实例对象,否则,按类加载器的委托机制去搜索和加载该类,如果所有的类加载器都无法加载到该类,则抛出 ClassNotFoundException。加载完这个 Class 字节码后,接着就可以使用 Class 字节码的 newInstance 方法去创建该类的实例对象了。有时候,我们程序中所有使用的具体类名在设计时(即开发时)无法确定,只有程序运行时 才能确定,这时候就需要使用 Class.forName 去动态加载该类,这个类名通常是在配置文件 中配置的,例如,spring 的 ioc 中每次依赖注入的具体类就是这样配置的,jdbc 的驱动类名 通常也是通过配置文件来配置的,以便在产品交付使用后不用修改源程序就可以更换驱动类 名。
大数据量下的分页解决方法。
最好的办法是利用 sql 语句进行分页,这样每次查询出的结果集中就只包含某页的数据 内容。在 sql 语句无法实现分页的情况下,可以考虑对大的结果集通过游标定位方式来获取 某页的数据。
说出数据连接池的工作机制是什么?
J2EE 服务器启动时会建立一定数量的池连接,并一 直维持不少于此数目的池连接。客户端 程序需要连接时,池驱动程序会返回一个未使用的池连接并将其表记为忙。如果当前没有空 闲连接,池驱动程序就新建一定数量的连接,新建连接的数量有配置参数决定。当使用的池 连接调用完成后,池驱动程序将此连接表记为空闲,其他调用就可以使用这个连接。实现方式,返回的 Connection 是原始 Connection 的代理,代理 Connection 的 close 方法不是 真正关连接,而是把它代理的 Connection 对象还回到连接池中。
为什么要用 ORM? 和 JDBC 有何不一样?
orm 是一种思想,就是把 object 转变成数据库中的记录,或者把数据库中的记录转变成 object,我们可以用 jdbc 来实现这种思想,其实,如果我们的项目是严格按照 oop 方式编 写的话,我们的 jdbc 程序不管是有意还是无意,就已经在实现 orm 的工作了。现在有许多 orm 工具,它们底层调用 jdbc 来实现了 orm 工作,我们直接使用这些工具,就 省去了直接使用 jdbc 的繁琐细节,提高了开发效率,现在用的较多的 orm 工具是 hibernate。也听说一些其他 orm 工具,如 toplink,ojb 等。
XML 部分
xml 有哪些解析技术?区别是什么?
有 DOM,SAX,STAX 等 DOM:处理大型文件时其性能下降的非常厉害。这个问题是由 DOM 的树结构所造成的,这种结构占用的内存较多,而且 DOM 必须在解析文件之前把整个文档装入内存,适合对 XML 的随机访问 SAX:不现于 DOM,SAX 是事件驱动型的 XML 解析方式。它顺序读取 XML 文 件,不需要一次全部装载整个文件。当遇到像文件开头,文档结束,或者标签开头与标签结 束时,它会触发一个事件,用户通过在其回调事件中写入处理代码来处理 XML 文件,适合 对 XML 的顺序访问 STAX:StreamingAPI forXML(StAX)
你在项目中用到了 xml 技术的哪些方面?如何实现的?
用到了数据存贮,信息配置两方面。在做数据交换平台时,将不能数据源的数据组装成 XML 文件,然后将 XML 文件压缩打包加密后通过网络传送给接收者,接收解密与解压缩 后再同 XML 文件中还原相关信息进行处理。在做软件配置时,利用 XML 可以很方便的进 行,软件的各种配置参数都存贮在 XML 文件中。
XML 文档定义有几种形式?它们之间有何本质区别?解析 XML 文档有哪几种方式?
a: 两种形式 dtd schema,b: 本质区别:schema 本身是 xml 的,可以被 XML 解析器解析(这 也是从 DTD 上发展 schema 的根本目的),c:有 DOM,SAX,STAX 等 DOM:处理大型文件时其性能下降的非常厉害。这个问题是由 DOM 的树结构所造成的,这 种结构占用的内存较多,而且 DOM 必须在解析文件之前把整个文档装入内存,适合对 XML 的随机访问。
SAX:不现于 DOM,SAX 是事件驱动型的 XML 解析方式。它顺序读取 XML 文件,不需要一 次全部装载整个文件。当遇到像文件开头,文档结束,或者标签开头与标签结束时,它会触 发一个事件,用户通过在其回调事件中写入处理代码来处理 XML 文件,适合对 XML 的顺 序访问。
流行的框架与新技术
谈谈你对 SSH 的理解
典型的 JavaEE 三层结构,分为表现层、中间层(业务逻辑层)和数据服务层。三层体系将 业务规则、数据访问及合法性校验等工作放在中间层处理。客户端不直接与数据库交互,而 是通过组件与中间层建立连接,再由中间层与数据库交互。
表现层是传统的 JSP 技术,自 1999 年问世以来,经过多年的发展,其广泛的应用和稳定的 表现,为其作为表现层技术打下了坚实的基础。
中间层采用的是流行的 Spring+Hibernate,为了将控制层与业务逻辑层分离,又细分为以下 几种。
Web 层,就是 MVC 模式里面的“C”(controller),负责控制业务逻辑层与表现层的交互, 调用业务逻辑层,并将业务数据返回给表现层作组织表现,该系统的 MVC 框架采用 Struts。
Service 层(就是业务逻辑层),负责实现业务逻辑。业务逻辑层以 DAO 层为基础,通过对 DAO 组件的正面模式包装,完成系统所要求的业务逻辑。
DAO 层,负责与持久化对象交互。该层封装了数据的增、删、查、改的操作。PO,持久化对象。通过实体关系映射工具将关系型数据库的数据映射成对象,很方便地实 现以面向对象方式操作数据库,该系统采用 Hibernate 作为 ORM 框架。
Spring 的作用贯穿了整个中间层,将 Web 层、Service 层、DAO 层及 PO 无缝整合,其数据 服务层用来存放数据。
谈谈你对 Hibernate 的理解。
1. 面向对象设计的软件内部运行过程可以理解成就是在不断创建各种新对象、建立对象之 间的关系,调用对象的方法来改变各个对象的状态和对象消亡的过程,不管程序运行的过程和操作怎么样,本质上都是要得到一个结果,程序上一个时刻和下一个时刻的运行结果的差 异就表现在内存中的对象状态发生了变化。
2.为了在关机和内存空间不够的状况下,保持程序的运行状态,需要将内存中的对象状态保 存到持久化设备和从持久化设备中恢复出对象的状态,通常都是保存到关系数据库来保存大 量对象信息。从 Java 程序的运行功能上来讲,保存对象状态的功能相比系统运行的其他功 能来说,应该是一个很不起眼的附属功能,java 采用 jdbc 来实现这个功能,这个不起眼的 功能却要编写大量的代码,而做的事情仅仅是保存对象和恢复对象,并且那些大量的 jdbc 代码并没有什么技术含量,基本上是采用一套例行公事的标准代码模板来编写,是一种苦活 和重复性的工作。
3.通过数据库保存 java 程序运行时产生的对象和恢复对象,其实就是实现了 java 对象与关 系数据库记录的映射关系,称为 ORM(即 Object Relation Mapping),人们可以通过封装 JDBC 代码来实现了这种功能,封装出来的产品称之为 ORM 框架,Hibernate 就是其中的一 种流行 ORM 框架。使用 Hibernate 框架,不用写 JDBC 代码,仅仅是调用一个 save 方法, 就可以将对象保存到关系数据库中,仅仅是调用一个 get 方法,就可以从数据库中加载出一 个对象。
4.使用 Hibernate 的基本流程是:配置 Configuration 对象、产生 SessionFactory、创建 session 对象,启动事务,完成 CRUD 操作,提交事务,关闭 session。
5.使用 Hibernate 时,先要配置 hibernate.cfg.xml 文件,其中配置数据库连接信息和方言等, 还要为每个实体配置相应的 hbm.xml 文件,hibernate.cfg.xml 文件中需要登记每个 hbm.xml 文件。
6.在应用 Hibernate 时,重点要了解 Session 的缓存原理,级联,延迟加载和 hql 查询。
AOP 的作用。
面向切面编程(AOP)提供另外一种角度来思考程序结构,通过这种方式弥补了面向对象编 程(OOP)的不足 。
除了类(classes)以外,AOP 提供了切面。切面对关注点进行模块化,例如横切多个类型和 对象的事务管理 。
Spring的一个关键的组件就是AOP框架,可以自由选择是否使用AOP提供声明式企业服务, 特别是为了替代 EJB 声明式服务。最重要的服务是声明性事务管理,这个服务建立在 Spring 的抽象事物管理之上 。
允许用户实现自定义切面,用 AOP 来完善 OOP 的使用.可以把 SpringAOP 看作是对 Spring 的一种增强 。
你对 Spring 的理解。
1.Spring 实现了工厂模式的工厂类(在这里有必要解释清楚什么是工厂模式),这个类名为 BeanFactory(实际上是一个接口),在程序中通常 BeanFactory 的子类 ApplicationContext。 Spring 相当于一个大的工厂类,在其配置文件中通过元素配置用于创建实例对象的类 名和实例对象的属性。
2.Spring 提供了对 IOC 良好支持,IOC 是一种编程思想,是一种架构艺术,利用这种思想 可以很好地实现模块之间的解耦。IOC 也称为 DI(DepencyInjection),什么叫依赖注入呢?
3.Spring 提供了对 AOP 技术的良好封装, AOP 称为面向切面编程,就是系统中有很多各 不相干的类的方法,在这些众多方法中要加入某种系统功能的代码,例如,加入日志,加入 权限判断,加入异常处理,这种应用称为 AOP。实现 AOP 功能采用的是代理技术,客户端 程序不再调用目标,而调用代理类,代理类与目标类对外具有相同的方法声明,有两种方式 可以实现相同的方法声明,一是实现相同的接口,二是作为目标的子类在, JDK 中采用 Proxy 类产生动态代理的方式为某个接口生成实现类,如果要为某个类生成子类,则可以用 CGLI B。在生成的代理类的方法中加入系统功能和调用目标类的相应方法,系统功能的代理以 Advice 对象进行提供,显然要创建出代理对象,至少需要目标类和 Advice 类。spring 提供 了这种支持,只需要在 spring 配置文件中配置这两个元素即可实现代理和 aop 功能。
hibernate 中的 update()和 saveOrUpdate()的区别,session 的 load()和 get()的区别。 简述 Hibernate 和 JDBC 的优缺点? 如何书写一个 one tomany 配置文件.Hibernate 的应用(Hibernate 的结构)?
//首先获得 SessionFactory 的对象 SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory(); //然后获得 session 的对象 Session session = sessionFactory.openSession(); //其次获得 Transaction 的对象 Transaction tx = session.beginTransaction(); //执行相关的数据库操作:增,删,改,查 session.save(user); //增加,user 是 User 类的对象 session.delete(user); //删除 session.update(user); //更新 Queryquery=session.createQuery(“fromUser”); //查询 List list =query.list(); //提交事务 tx.commit(); //如果有异常,我们还要作事务的回滚,恢复到操作之前 tx.rollback(); //最后还要关闭 session,释放资源 session.close()
Hibernate 有哪 5 个核心接口?
Configuration 接口:配置 Hibernate,根据其启动 hibernate,创建 SessionFactory 对象;
SessionFactory 接口:初始化 Hibernate,充当数据存储源的代理,创建 session 对象, sessionFactory 是线程安全的,意味着它的同一个实例可以被应用的多个线程共享,是重量 级、二级缓存;
Session 接口:负责保存、更新、删除、加载和查询对象,是线程不安全的,避免多个 线程共享同一个 session,是轻量级、一级缓存;
Transaction 接口:管理事务;
Query 和 Criteria 接口:执行数据库的查询。
iBatis 与 Hibernate 有什么不同?
相同点:屏蔽 jdbcapi 的底层访问细节,使用我们不用与 jdbcapi 打交道,就可以访问数据。jdbcapi 编程流程固定,还将 sql 语句与 java 代码混杂在了一起,经常需要拼凑 sql 语句,细 节很繁琐。
ibatis 的好处:屏蔽 jdbc api 的底层访问细节;将 sql 语句与 java 代码进行分离;提供了将结果集自动封装称为实体对象和对象的集合的功能,queryForList 返回对象集合,用 queryForObject 返回单个对象;提供了自动将实体对象的属性传递给 sql 语句的参数。
Hibernate是一个全自动的orm映射工具,它可以自动生成sql语句,ibatis需要我们自己在xml 配置文件中写 sql 语句,hibernate 要比 ibatis 功能负责和强大很多。因为 hibernate 自动生成 sql 语句,我们无法控制该语句,我们就无法去写特定的高效率的 sql。对于一些不太复杂的 sql 查询,hibernate 可以很好帮我们完成,但是,对于特别复杂的查询,hibernate 就很难适 应了,这时候用 ibatis 就是不错的选择,因为 ibatis 还是由我们自己写 sql 语句。
写 Hibernate 的一对多和多对一双向关联的 orm 配置?
什么是 ORM?
对象关系映射(Object—Relational Mapping,简称 ORM)是一种为了解决面向对象与 面向关系数据库存在的互不匹配的现象的技术;简单的说,ORM 是通过使用描述对象和数 据库之间映射的元数据,将 java 程序中的对象自动持久化到关系数据库中;本质上就是将 数据从一种形式转换到另外一种形式。
hibernate 的 inverse 属性的作用?
解决方案一,按照 Object[]数据取出数据,然后自己组 bean
解决方案二,对每个表的 bean 写构造函数,比如表一要查出 field1,field2 两个字段,那么有 一个构造函数就是 Bean(type1filed1,type2 field2) ,然后在 hql 里面就可以直接生成这个 bean 了。
在 DAO 中如何体现 DAO 设计模式?
解决方案一,按照 Object[]数据取出数据,然后自己组 bean
解决方案二,对每个表的 bean 写构造函数,比如表一要查出 field1,field2 两个字段,那么有 一个构造函数就是 Bean(type1filed1,type2 field2) ,然后在 hql 里面就可以直接生成这个 bean 了。
spring+Hibernate 中委托方案怎么配置?
解决方案一,按照 Object[]数据取出数据,然后自己组 bean
解决方案二,对每个表的 bean 写构造函数,比如表一要查出 field1,field2 两个字段,那么有 一个构造函数就是 Bean(type1filed1,type2 field2) ,然后在 hql 里面就可以直接生成这个 bean 了。
hibernate 进行多表查询每表中各取几个字段,就是说查询出的结果集没有一个实体 类与之对应如何解决 ?
解决方案一,按照 Object[]数据取出数据,然后自己组 bean
解决方案二,对每个表的 bean 写构造函数,比如表一要查出 field1,field2 两个字段,那么有 一个构造函数就是 Bean(type1filed1,type2 field2) ,然后在 hql 里面就可以直接生成这个 bean 了。
介绍一下 Hibernate 的二级缓存
按照以下思路来回答:(1)首先说清楚什么是缓存,(2)再说有了 hibernate 的 Session 就 是一级缓存,即有了一级缓存,为什么还要有二级缓存,(3)最后再说如何配置 Hibernate 的二级缓存。
(1)缓存就是把以前从数据库中查询出来和使用过的对象保存在内存中(一个数据结构中), 这个数据结构通常是类似于 Hashmap,当以后要使用某个对象时,先查询缓存中是否有这个 对象,如果有则使用缓存中的对象,如果没有则去查询数据库,并将查询出来的对象保存在 缓存中,以便下次使用。
(2)Hibernate 的 Session 就是一种缓存,我们通常将之称为 Hibernate 的一级缓存,当想使 用session从数据库中查询出一个对象时, Session也是先从自己内部查看是否存在这个对象, 存在则直接返回,不存在才去访问数据库,并将查询的结果保存在自己内部。由于 Session 代表一次会话过程,一个 Session 与一个数据库连接相关连,所以 Session 最好不要长时间 保持打开,通常仅用于一个事务当中,在事务结束时就应关闭。并且 Session 是线程不安全的,被多个线程共享时容易出现问题。通常只有那种全局意义上的缓存才是真正的缓存应用, 才有较大的缓存价值,因此,Hibernate 的 Session 这一级缓存的缓存作用并不明显,应用价 值不大。Hibernate 的二级缓存就是要为 Hibernate 配置一种全局缓存,让多个线程和多个事 务都可以共享这个缓存。我们希望的是一个人使用过,其他人也可以使用,session 没有这 种效果。
(3)二级缓存是独立于 Hibernate 的软件部件,属于第三方的产品,多个厂商和组织都提供 有缓存产品,例如,EHCache 和 OSCache 等等。在 Hibernate 中使用二级缓存,首先就要在 hibernate.cfg.xml 配置文件中配置使用哪个厂家的缓存产品,接着需要配置该缓存产品自己 的配置文件,最后要配置 Hibernate 中的哪些实体对象要纳入到二级缓存的管理中。明白了 二级缓存原理和有了这个思路后,很容易配置起 Hibernate 的二级缓存。扩展知识:一个 SessionFactory 可以关联一个二级缓存,也即一个二级缓存只能负责缓存一个数据库中的数 据,当使用 Hibernate 的二级缓存后,注意不要有其他的应用或 SessionFactory 来更改当前 数据库中的数据,这样缓存的数据就会与数据库中的实际数据不一致。
解释 Spring 的依赖注入? 给一个 Bean 的 message 属性, 字符串类型, 注入值为 "Hello"的 XML 配置文件该怎么写?
Jdo 是什么?
JDO 是 Java 对象持久化的新的规范,为 java dataobject 的简称,也是一个用于存取某种数据 仓库中的对象的标准化 API。JDO 提供了透明的对象存储,因此对开发人员来说,存储数据 对象完全不需要额外的代码(如 JDBCAPI 的使用)。这些繁琐的例行工作已经转移到 JDO 产品提供商身上,使开发人员解脱出来,从而集中时间和精力在业务逻辑上。另外,JDO 很灵活,因为它可以在任何数据底层上运行。JDBC 只是面向关系数据库(RDBMS)JDO 更通用,提供到任何数据底层的存储功能,比如关系数据库、文件、XML 以及对象数据库 (ODBMS)等等,使得应用可移植性更强。
spring 与 EJB 的区别!