今天在加载数据库的时候碰到了这两个东西。
知识点:反射。
首先加载数据库驱动的时候用到了Class.forname。
用法:
Class.forname(“类名”),注意需要加上包的路径
作用:
首先java要执行程序编译后需要虚拟机进行加载,Class.forname便是让虚拟机加载指定的类,一般类里都会静态块,这样加载时静态块就会运行,实现一些初始化操作。
例子:
如加载数据库驱动的时候就会执行数据库里的静态代码,实现数据库的链接。
public class MyJDBCDriver implements Driver {
static {
DriverManager.registerDriver(new MyJDBCDriver());
}
}
具体详细的可以自己去看反射。
顺便提一下静态块小知识
执行时间:第一次加载类的时候
一般第一次访问类的静态变量,方法,或者第一次实例化A时都会加载类
详细顺序是:
先父类的static成员变量-》子类的static成员变量-》父类的成员变量-》父类构造-》子类成员变量-》子类构造
还有class小知识
Class.forName(“XXXX”)…..;与XXXX.class….有什么区别?
Class.forName(“XXXX”);的作用是要求JVM查找并加载指定的类,如果在类中有静态初始化的话,JVM必然会执行该类的静态代码段,这时是不确定该类是否已经在JVM中加载。而XXXX.class是在JVM中加载已经加载过的类。
关于SelectMethod=Cursor
直接copy的。。。
今天在数据库连接字符串中看到了selectMethod=cursor
知道了这个用法如下:
作用:以利用服务器端的游标加快速度
使用情况:
1.执行多个Statements的操作的时候用
2.需要手动使用事务的时候使用
protected static String dburl = "jdbc:sqlserver://localhost:1433;"
+ "DatabaseName=db_database299;SelectMethod=Cursor";
参考资料:
http://www.cnblogs.com/shosky/archive/2011/07/22/2114290.htm