第七课(JDBC)-- 使用一个Java类(DBconn)去连接MySql

直接在包中定义一个Java类,可以选class,也可以选servlet,因为servlet本质上还是一个Java类,只是在选择servlet时,创建的文件已经写好了继承httpservlet,导入了需要的包,重写了goget/dopost方法,而class只是一个类的框架,没有做任何处理,所以想从头开始一点点将一个class文件变成servlet可以尝试创建class文件再通过继承、导包和重写来实现。

以下定义了一个DBconn的servlet

package tools;  
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class DBconn {
	String JDBC_DRIVER = "com.mysql.jdbc.Driver"; 
	String DB_URL = "jdbc:mysql://localhost:3306/test";
	//选择要连接的数据库,test部分可变(填要连接的DB名称)
    String USER = "root";
    String PASS = "123456789";
    //填写连接该DB的账户名与密码
	Connection conn = null;
	public Connection DBconn() {
		/*Connection是一个接口
		//用于向数据库发送SQL语句
		 * 用于在后面接收DriverManager与DB建立的连接
		 * 接收之后可以通过调用Connection下的多种方法
		 * 去实现对DB的增删改查
		 * 其本质就是传递sql语句
		 */
		try {
				Class.forName(JDBC_DRIVER);
				// 将mysql驱动注册到DriverManager中去
				/*
				 * Class.forName() 方法要求JVM查找并加载指定的类到内存中,
				 * 此时将"com.mysql.jdbc.Driver" 当做参数传入,
				 * 就是告诉JVM,去"com.mysql.jdbc"这个路径下找Driver类,
				 * 将其加载到内存中
				 * 作用就是将对应DB的驱动加载到DriverManager中
				 * 使得DriverManager知道应该调用对应于该驱动的连接方法去连接该DB
				 * https://www.cnblogs.com/qingchen521/p/10331768.html
				 */
				conn = DriverManager.getConnection(DB_URL,USER,PASS);
				 // 通过DriverManager的getConnection用于尝试建立与给定数据库URL的连接
				//因此参数应该给出指定的DB名、用户名、密码
				System.out.println("成功连接数据库..");
				//提示连接成功
		} catch (SQLException e) {
			e.printStackTrace();
		}catch (ClassNotFoundException e) {
			e.printStackTrace();
		}
		return conn;
	}
	public static void main(String[] args) {
		DBconn dbconnection = new DBconn();
		dbconnection.DBconn();
	}

}

通过以上代码在myeclipse中运行就可以连接上MySQL数据库啦!

package com.hexiang.utils.dao; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.Properties; import javax.naming.Context; import javax.naming.InitialContext; import javax.naming.NamingException; import javax.sql.DataSource; import org.apache.log4j.Logger; public class DBConnection { /** * 获得与数据库的连接 * * @param path * @return Connection */ public static Connection getConn(String classDriver, String url, String user, String pwd) { try { Class.forName(classDriver); return DriverManager.getConnection(url, user, pwd); } catch (ClassNotFoundException ex) { ex.printStackTrace(); } catch (SQLException ex) { ex.printStackTrace(); } return null; } public static Connection getConn(DataSource dataSource) { try { return dataSource.getConnection(); } catch (SQLException ex) { ex.printStackTrace(); } return null; } public static Connection getConn(String jndiName) { try { Context ctx; ctx = new InitialContext(); DataSource dataSource = (DataSource) ctx.lookup("java:comp/env/" + jndiName); return dataSource.getConnection(); } catch (NamingException ex) { ex.printStackTrace(); } catch (SQLException ex) { ex.printStackTrace(); } return null; } public static Connection getConn(Properties properties) { try { String driver = properties.getProperty("jdbc.driverClassName"); String url = properties.getProperty("jdbc.url"); String user = properties.getProperty("jdbc.username"); String password = properties.getProperty("jdbc.password"); Class.forName(driver); return DriverManager.getConnection(url, user, password); } catch (ClassNotFoundException ex) { ex.printStackTrace(); } catch (SQLException ex) { ex.printStackTrace(); } return null; } /** * oracle连接 * * @param path * @return Connection */ public static Connection getOracleConn(String
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值