JDBC基础理解与实现操作

3 篇文章 0 订阅

    一,基本理解

  1. JDBC是通过Java语言来操纵数据库的一套API
  2. 全称(Java DataBase Connectivity)java数据库连接
  3.  JDBC就是一套标准接口  
  4. 我们可以通过使用JDBC这套接口,真正执行的代码是数据库的 驱动
  5. 数据库的驱动就是实现类 用来实现JDBC接口, 实现了同一套Java代码,可以操作不同的数据库
  6. 真正执行代码的是驱动jar包中的实现类,不同的数据库都有自己的实现类  俗称驱动  。

    二,实现步骤    

                首先创建项目,导入驱动jar包     *用什么数据库就导什么驱动 不同数据库驱动不一样

   第一步:

                main方法

   第二步:注册驱动或叫加载数据库的驱动类

                Class.formName("com.mysql.jdbc.Driver");   //遇到异常直接抛出即可
    
   第三步:获取与数据库的连接  通过DriverManger类的静态方法 来实现,
                 实现后用对象接收例 conn
        
                 String url="jdbc:mysql://127.0.0.1:3306/写要连接的数据库名字";   
                                                 //jdbc:mysql://127.0.0.1:3306/ 是固定格式
                 String username="写要连接的数据库用户名"
                 String password="写要连接的数据库的密码


                 Connection conn =DriverManger.getConnection(url ,username,password);

    第四步: 编写sql语句   并用变量接收 

                String sql = “sql语句”;
    

    第五步:  获取执行sql的对象 statement   通过conn.createStatement()方法打 来获取对象

   
                Statement stmt=conn.createStatement();

    第六步:执行sql语句  通过stmt.excuteUpdate来执行

                int count=stmt.executeUpdate(sql);  //控制台会返回受影响的行数

    第七步:处理结果  控制台输出一下
        
                System.out.orintIn(count);

    第八步:释放资源   因为先开的conn 后开的stmt

                stmt.close();
                conn.close();

 三,代码实操

JDBC连接mysql数据库示例一:

   需求说明:通过Java实现MySQL数据库的 表数据更新。 update

package com.java2.db;

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

public class Test01 {
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
        //注册驱动
        Class.forName("com.mysql.jdbc.Driver");
        //获取与数据库的连接
       Connection conn= DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/epet","root","123456");
        //编写sql
         String sql="update pet set name='小花' where id=3";
        //通过 conn.createStatement()方法 获取执行对象
        Statement stmt=conn.createStatement();
        //通过stmt.executeUpdate 来执行sql语句
            int count=stmt.executeUpdate(sql);
        //控制台输出 受影响的行数
        System.out.println(count);
        //关闭对象或叫释放资源
        stmt.close();
        conn.close();

    }
}

JDBC连接mysql数据库示例二:

 需求说明:通过Java实现MySQL数据库的 表数据查询。  select

package com.java2.db;

import java.sql.*;

import static java.lang.Class.forName;

/**
 * jdbc连接mysql数据库示例
 */
public class DBConnertionDemo01 {
    public static void main(String[]args) throws ClassNotFoundException, SQLException {
        //加载数据库驱动类
        Class.forName("com.mysql.jdbc.Driver");
        //获取数据库连接
        Connection con=DriverManager.getConnection("jdbc:mysql://localhost:3306/test",
                "root","123456");
        //通过连接对象con获取
        Statement statement= con.createStatement();
        //编写sql语句,sql的作用是查询student表的所有学生信息
        String sql="select sid,sname,gender,class_id from student";
        //执行sql语句,并且用ResultSet来接受查询后返回的数据
        ResultSet sets=statement.executeQuery(sql);
        while (sets.next()){
            int sid=sets.getInt("sid");
           String sname= sets.getString("sname");
           String gender=sets.getString("gender");
           int classid=sets.getInt("class_id");
            System.out.println("学生id:"+sid+"学生姓名:"+sname
                             +"学生性别:"+gender+"所在班级id:"+classid);
        }
        con.close();
    }
}


动态实现    

        需求说明:通过Java实现MySQL数据库的 表数据更新。 update

package com.java2.db;

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

public class Test01 {
    public static void main(String[] args) throws Exception {

        updateTest2("旺财",2);
    }



    public  static void  updateTest2(String name,int id) throws Exception{
        Class.forName("com.mysql.jdbc.Driver");

        Connection connection=DriverManager.getConnection

        ("jdbc:mysql://localhost:3306/epet","root","123456");

        Statement statement=connection.createStatement();

        statement.execute("update pet set name='"+name+"' where id="+id+"");
        connection.close();
    }
}

JDBC连接mysql数据库示例三:

        需求说明:通过Java实现MySQL数据库的 表数据查询。 select

public class DogDemo {
    /**
     *  查询每一个主人养的宠物的数量
     */
    public static void main(String[] args) throws ClassNotFoundException, SQLException, IOException {
        selectCount();

    }

    public static  void  selectCount() throws ClassNotFoundException, SQLException {
        //连接数据库
        Class.forName("com.mysql.jdbc.Driver");
        Connection connection=DriverManager.getConnection
                ("jdbc:mysql://localhost:3306/epet","root","123456");

        //编写sql
        String sql="SELECT hoster.name,COUNT(pet.id) sum FROM hoster INNER JOIN pet ON             
         pet.hoster_id=hoster.id GROUP BY hoster.name;";

        //执行sql语句
        Statement statement=connection.createStatement();
        ResultSet re=statement.executeQuery(sql);

        System.out.println("每个主人养的宠物数量是:");
     //循环 判断该表中的下一行有没有值 有就输出 没有就结束
        while (re.next()){
            String name= re.getString("name");
            int sum=re.getInt("sum");
            System.out.println(name+" "+sum);
        }
    }



}

JDBC连接mysql数据库示例三:

需求说明:通过Java实现MySQL数据库的 表数据新增。 insert  

                   使用 PreparedStatement 完成

  /**
     * 插入宠物信息3
     */
    public static  void insertDog3() throws SQLException, IOException, ClassNotFoundException {
        //连接数据库
        Connection connection= DBUtil.getConnection();
        
        
        String sql="insert into pet(name,strain)values(?,?)";
        PreparedStatement preparedStatement=connection.prepareStatement(sql);
        preparedStatement.setString(1,"白景瑞");
        preparedStatement.setString(2,"拉布拉多");
        preparedStatement.execute();
        preparedStatement.close();
        connection.close();
    }




public class DogDemo {

    public static void main(String[] args) throws ClassNotFoundException, SQLException, IOException {
        
                insertDog3();

    }
//方法
     public static  void insertDog3() throws SQLException, IOException, ClassNotFoundException {               

        //连接数据库
        Connection connection= DBUtil.getConnection();
              
        String sql="insert into pet(name,strain)values(?,?)";
        PreparedStatement preparedStatement=connection.prepareStatement(sql);
        preparedStatement.setString(1,"白景瑞");
        preparedStatement.setString(2,"拉布拉多");
        preparedStatement.execute();
        preparedStatement.close();
        connection.close();
    
    }

}

四,常用方法

Statement常用方法

方法名

说    明 ResultSet executeQuery(String sql) 执行SQL查询并获取到ResultSet对象 int executeUpdate(String sql) 可以执行插入、删除、更新等操作,返回值是执行该操作所影响的行数 boolean execute(String sql) 可以执行任意SQL语句,然后获得一个布尔值,表示是否返回ResultSet

ResultSet常用方法
方法名说    明
boolean next()将光标从当前位置向下移动一行                                            
boolean previous()游标从当前位置向上移动一行
void close()关闭ResultSet 对象
int getInt(int colIndex)以int形式获取结果集当前行指定列号值
int getInt(String colLabel)以int形式获取结果集当前行指定列名值
float getFloat(int colIndex)以float形式获取结果集当前行指定列号值
float getFloat(String colLabel)以float形式获取结果集当前行指定列名值
String getString(int colIndex)以String 形式获取结果集当前行指定列号值
String getString(String colLabel)以String形式获取结果集当前行指定列名值

**小提示**

PreparedStatement 接口继承 Statement接口 PreparedStatement比普通的Statement对象使用起来更加灵活,更有效率   ,尽量使用PreparedStatement,尽量不使用Statement。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值