面向对象—(JDBC(2))

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注入。      

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值