【JAVA】JDBC连接数据库

导入jdbc驱动:

1.java项目:

右键项目->Build Path->Configure Build Path...->Libraries->Modulepath->Add External JARs...

选择jdbc驱动即可。


2.java web项目

复制jdbc驱动,粘贴到项目的WebContent->WEB-INIF->lib下,即可。

(java web项目如果按照1中的方法导入驱动,会出现null pointer错误)

-------------------------------------------------------------------------------

demo:

public class JDBCdemo {
	private static final String DBDRIVER = "com.mysql.jdbc.Driver";
	private static final String DBURL = "jdbc:mysql://localhost:3306/example";
	private static final String DBUSER = "root";
	private static final String DBPASS = "xxxx";
	private Connection connection = null;
	
	public static void main(String[] args) {
		JDBCdemo dbc = new JDBCdemo();
		dbc.getConnection();
	}

	public JDBCdemo() {
		try {
			System.out.println("connection begin");
			Class.forName(DBDRIVER);
			connection = DriverManager.getConnection(DBURL, DBUSER, DBPASS);
			System.out.println("connection successful!");
			connection.close();
		} catch (Exception e) {
			e.printStackTrace();;
		} finally {
		}
	}
	
	public Connection getConnection() {
		return connection;
	}
	
	public void close() throws Exception {
		if (connection != null) {
			try {
				connection.close();
			} catch (Exception e) {
				throw e;
			}
		}
	}
}

加载数据库驱动时使用Class.forName(DBDVIVER)的原因:

Class.forName("");的作用是要求JVM查找并加载指定的类,如果在类中有静态初始化器的话,JVM必然会执行该类的静态代码 段。

而在JDBC规范中明确要求这个Driver类必须向DriverManager注册自己,即任何一个JDBC 

Driver的 Driver类的代码都必须类似如下:
  public  class  MyJDBCDriver  implements  Driver  {
    static  {
        DriverManager.registerDriver(new  MyJDBCDriver());
  }
  }
既然在静态初始化器的中已经进行了注册,所以我们在使用JDBC时只需要Class.forName(XXX.XXX);就可以了。

https://www.cnblogs.com/shosky/archive/2011/07/22/2114290.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值