JDBC连接数据库的步骤

JDBC连接数据库的步骤

  • 注册驱动

    Class.forName(“com.mysql.jdbc.Dirver”); 推荐使用这种方式,不会对具体的驱动类产生依赖。

    DirverManager.registerDirver(com.mysql.jdbc.Driver);会造成DirverManager中产生两个一样的驱动,并会对具体的驱动类产生依赖

    System.setProperty(“jdbc.dirvers”,”driver1:driver2”);虽然不会对具体的驱动类产生依赖,但是注册不太方便,很少使用

  • 建立连接(Connecton)
    Connection conn=DirverManager.getConnection(url.user,password);

    url格式:JDBC:子协议:子名称//主机名:端口/数据库名?属性名=属性值&...
    :jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8";
    
    User passord可以用“属性名=属性值”方式告诉数据库
    
    其他参数参加:useUnacode = true&characterEncoding=utf-8.
    
  • 创建执行SQL的语句(Statement)

  • 执行语句

  • 处理执行结果(ResultSet)

  • 释放资源

package cn.congxing.jdbc;

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

public class JdbcTest {

 public static void main(String[] args) {

  //数据库连接对象
  Connection connection =null;
  //预编译statement
  PreparedStatement preparedStatement=null;
  //结果集
  ResultSet resultSet= null;
  String url="jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8";
  String username="root";
  String password="123";

  try {
   //注册加载驱动
   Class.forName("com.mysql.jdbc.Driver");
   //获取连接
   connection = DriverManager.getConnection(url, username, password);
   //定义sql
   String sql = "select * from user where username= ?";
   //获取预处理statement
   preparedStatement = connection.prepareStatement(sql);
   preparedStatement.setString(1, "王五");
   //向数据库发出sql执行查询,查询出结果集
   resultSet = preparedStatement.executeQuery();
   //遍历查询结果集
   while(resultSet.next()){
    System.out.println(resultSet.getString("id")+"--"+resultSet.getString("username"));
   }
  } catch (Exception e) {
   e.printStackTrace();
  }finally{
   //释放资源
   if(resultSet!=null){
    try {
     resultSet.close();
    } catch (SQLException e) {
     e.printStackTrace();
    }
   }
   if(preparedStatement!=null){
    try {
     preparedStatement.close();
    } catch (SQLException e) {
     e.printStackTrace();
    }
   }
   if(connection!=null){
    try {
     connection.close();
    } catch (SQLException e) {
     e.printStackTrace();
    }
   }

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值