1、什么是JDBC:
JDBC是Java数据库连接技术的简称,由一组使用Java语言编写的类和接口组成,可以为多种关系数据库提供统一访问。
2、JDBC访问数据库的步骤:
加载JDBC驱动
与数据库建立连接
发送SQL语句,并得到返回结果
处理返回结果
3.JVM(JAVA虚拟机)加载class文件的原理机制?
JVM中类的装载是由ClassLoader和它的子类来实现的,Java ClassLoader是一个重要的Java运行时系统组件,他负责在运行时查找和装入类文件的类
4.ClassLoader(类加载器)如何加载class?
JVM(JAVA虚拟机)里有多个类加载器,每个类加载器可以负责加载特定位置的类,例如,bootstrap类加载器负责加载jre/lib/rt.jar中的类, 我们平时用的jdk中的类都位于rt.jar中。extclassloader负责加载jar/lib/ext/*.jar中的类,appclassloader负责classpath指定的目录或jar中的类。除了bootstrap之外,其他的类加载器本身也都是java类,它们的父类是ClassLoader。
5、Class.forName的作用?为什么要用?
调用该访问返回一个以字符串指定类名的类的对象。
按参数中指定的字符串形式的类名去搜索并加载相应的类,如果该类字节码已经被加载过,则返回代表该字节码的Class实例对象,否则,按类加载器的委托机制去搜索和加载该类,如果所有的类加载器都无法加载到该类,则抛出ClassNotFoundException。加载完这个Class字节码后,接着就可以使用Class字节码的newInstance方法去创建该类的实例对象了。
有时候,我们程序中所有使用的具体类名在设计时(即开发时)无法确定,只有程序运行时才能确定,这时候就需要使用Class.forName去动态加载该类,这个类名通常是在配置文件中配置的,例如,spring的ioc中每次依赖注入的具体类就是这样配置的,jdbc的驱动类名通常也是通过配置文件来配置的,以便在产品交付使用后不用修改源程序就可以更换驱动类名。
6、用jdbc连接并访问oracle数据库的程序代码
Connection cn = null;
PreparedStatement pstmt =null;
Resultset rs = null;
try{
Class.forname(driveClassName);
cn = DriverManager.getConnection(url,username,password);
pstmt =cn.prepareStatement(“select * from userwhere username = ?”);
pstmt.setString(1,userName);
Resultset rs =pstmt.executeQuery();
while(rs.next()){
system.out.println(rs.getInt(“subject”) + “ |”+ rs.getFloat(“score”) );
}
}catch(Exception e){e.printStackTrace();}
finally{
if(rs != null)try{ rs.close() }catch(exception e){}
if(pstmt !=null) try{pstmt.close()}catch(exception e){}
if(cn != null)try{ cn.close() }catch(exception e){}
}
7、为什么用ORM?和JDBC有何不一样?
orm是一种思想,就是把object转变成数据库中的记录,或者把数据库中的记录转变成objecdt,我们可以用jdbc来实现这种思想,其实,如果我们的项目是严格按照oop方式编写的话,我们的jdbc程序不管是有意还是无意,就已经在实现orm的工作了。
现在有许多orm工具,它们底层调用jdbc来实现了orm工作,我们直接使用这些工具,就省去了直接使用jdbc的繁琐细节,提高了开发效率,现在用的较多的orm工具是hibernate。也听说一些其他orm工具,如toplink,ojb等
8、JDBC中的PreparedStatement相比Statement的好处:
一个sql命令发给服务器去执行的步骤为:语法检查,语义分析,编译成内部指令,缓存指令,执行指令等过程。
select * from student where id =3----缓存--�xxxxx二进制命令
select * from student where id =3----直接取-�xxxxx二进制命令
select * from student where id =4--- -�会怎么干?
如果当初是select * from student where id =?--- -�又会怎么干?
上面说的是性能提高,可以防止sql注入。