使用JDBC的基本步骤

JDBC

JAVA Database Connectivity java 数据库连接

  • 为什么会出现JDBC

SUN公司提供的一种数据库访问规则、规范, 由于数据库种类较多,并且java语言使用比较广泛,sun公司就提供了一种规范,让其他的数据库提供商去实现底层的访问规则。 我们的java程序只要使用sun公司提供的jdbc驱动即可。

使用JDBC的基本步骤

1. 注册驱动

DriverManager.registerDriver(new com.mysql.jdbc.Driver());

2. 建立连接

//DriverManager.getConnection("jdbc:mysql://localhost/test?user=monty&password=greatsqldb");
 //2. 建立连接 参数一: 协议 + 访问的数据库 , 参数二: 用户名 , 参数三: 密码。
 conn = DriverManager.getConnection("jdbc:mysql://localhost/student", "root", "root");

3. 创建statement

//3. 创建statement , 跟数据库打交道,一定需要这个对象
st = conn.createStatement();

4. 执行sql ,得到ResultSet

//4. 执行查询 , 得到结果集
	String sql = "select * from t_stu";
	rs = st.executeQuery(sql);

5. 遍历结果集

//5. 遍历查询每一条记录
	while(rs.next()){
		int id = rs.getInt("id");
		String name = rs.getString("name");
		int age = rs.getInt("age");
		System.out.println("id="+id + "===name="+name+"==age="+age);	
	}

6. 释放资源

if (rs != null) {
	        try {
	            rs.close();
	        } catch (SQLException sqlEx) { } // ignore 
	        rs = null;
	    }

完整代码:
package com.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import javax.naming.spi.DirStateFactory.Result;

public class MySqlTest {

public static void main(String[] args) {
	Connection conn=null;
	Statement st=null;
	ResultSet rs=null;
    try {
    	//1.注册驱动

// Class.forName(“com.mysql.jdbc.Driver”);
DriverManager.registerDriver(new com.mysql.jdbc.Driver());
String url=“jdbc:mysql://127.0.0.1:3306/student”;
String username=“root”;
String password=“123456”;

		//2.建立连接,参数(协议:访问的数据库、用户名、密码)
		conn = DriverManager.getConnection(url, username, password);
	   
		//3.创建数据库语句Statement 
		st = conn.createStatement();
       
		//4.执行查询
		String sql = "select * from t_stu";
		rs = st.executeQuery(sql);
		
		//5.遍历每一条记录
		while (rs.next()) {
			int id = rs.getInt("id");
			String name = rs.getString("name");
			int age = rs.getInt("age");
			System.out.println(id + "--" + name + "--" + age);
		}
		
		
    } catch (SQLException e) {
		e.printStackTrace();
	}finally {
		JDBCUtil.release(conn, st, rs);
	}
 }
}

JDBCUtil.java

package com.jdbc;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class JDBCUtil {
    /*释放资源*/
	public static void release(Connection conn,Statement st,ResultSet rs) {
		closeRs(rs);
		closeSt(st);
		closeConn(conn);
	}
	
	private static void closeRs(ResultSet rs) {
		try {
			if(rs != null) {
			    rs.close();
			}
		} catch (SQLException e) {
			e.printStackTrace();
		}finally {
			rs = null;
		}
	}
	
	private static void closeSt(Statement st) {
		try {
			if(st != null) {
			    st.close();
			}
		} catch (SQLException e) {
			e.printStackTrace();
		}finally {
			st = null;
		}
	}
	
	private static void closeConn(Connection conn) {
		try {
			if(conn != null) {
			    conn.close();
			}
		} catch (SQLException e) {
			e.printStackTrace();
		}finally {
			conn = null;
		}
	}
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值