JDBC

JDBC

  • 概念:Java DataBase Connectivity Java 数据库连接, Java语言操作数据库
  • JDBC本质:其实是官方(sun公司)定义的一套操作所有关系型数据库的规则,即接口。各个数据库厂商去实现这套接口,提供数据库驱动jar包。我们可以使用这套接口(JDBC)编程,真正执行的代码是驱动jar包中的实现类

JDBC使用步骤

  1. 导入驱动jar包 mysql-connector-java-5.1.37-bin.jar
    1.1 复制mysql-connector-java-5.1.37-bin.jar到项目的libs目录下
    1.2 右键–>Add As Library
  2. 注册驱动
  3. 获取数据库连接对象 Connection
  4. 定义sql
  5. 获取执行sql语句的对象 Statement
  6. 执行sql,接受返回结果
  7. 处理结果
  8. 释放资源

代码示例

package com.company;

import java.sql.*;
import java.util.logging.ConsoleHandler;

public class Main {

    public static void testCreateStatement()
    {
        Statement statementObj=null;
        Connection conObj=null;
        try{
            //1注册驱动
            /*
            static void registerDriver(Driver driver) :注册与给定的驱动程序 DriverManager 。
            写代码使用:  Class.forName("com.mysql.jdbc.Driver");
            通过查看源码发现:在com.mysql.jdbc.Driver类中存在静态代码块,加载Driver的时候会执行静态代码块(在这个类第一次被调用或实例化的时候就会被执行)
            static {
                try {
                    java.sql.DriverManager.registerDriver(new Driver());
                } catch (SQLException E) {
                    throw new RuntimeException("Can't register driver!");
                }
            }
            注意:mysql5之后的驱动jar包可以省略注册驱动的步骤。
            */
            Class.forName("com.mysql.jdbc.Driver");

            //2获取数据库连接对象 Connection
            /*
             * 方法:static Connection getConnection(String url, String user, String password)
             * 参数:
             * url:指定连接的路径
             * 语法:jdbc:mysql://ip地址(域名):端口号/数据库名称
             * 例子:jdbc:mysql://localhost:3306/mysql
             * 细节:如果连接的是本机mysql服务器,并且mysql服务默认端口是3306,则url可以简写为:jdbc:mysql://数据库名称
             * user:用户名
             * password:密码
             * */
            conObj= DriverManager.getConnection("jdbc:mysql://localhost:3306/mysql","root","root");

            //3定义sql
            //String sql = "insert into t_class values('2','高二')";
            String sql = "select * from t_class";
            //4获取执行sql语句的对象 Statement
            /*
             * 1. 获取执行sql 的对象
             * Statement createStatement()
             * PreparedStatement prepareStatement(String sql)
             * 2. 管理事务:
             * 开启事务:setAutoCommit(boolean autoCommit) :调用该方法设置参数为false,即开启事务
             * 提交事务:commit()
             * 回滚事务:rollback
             */
            	/*
           		什么时候使用事务:当你需要一次执行多条SQL语句时,可以使用事务。通俗一点说,就是,如果这几条SQL语句全部执行成功,则才对数据库进行一次更新,如果有一条SQL语句执行失败,则这几条SQL语句全部不进行执行,这个时候需要用到事务
           	 	*/
           	 /*
				try {
				//开启事务
				conObj.setAutoCommit(false);
				
				....执行多条sql的业务逻辑处理
				
				//最后提交事务
				//connection.commit();
				}catch (Exception e) {
					//如果发生异常则回滚事务
					try {
						//事务的回滚
						connection.rollback();
					} catch (SQLException e1) {
						e1.printStackTrace();
					}
				}
           	*/
			
			
			
            statementObj=conObj.createStatement();
            //4执行sql,接受返回结果
            /*
            * 3. Statement:执行sql的对象
		    	1. 执行sql
		    		1. boolean execute(String sql) :可以执行任意的sql 了解
		    		2. int executeUpdate(String sql) :执行DML(insert、update、delete)语句、DDL(create,alter、drop)语句
		    			* 返回值:影响的行数,可以通过这个影响的行数判断DML语句是否执行成功 返回值>0的则执行成功,反之,则失败。
		    		3. ResultSet executeQuery(String sql):执行DQL(select)语句
            * */
            ResultSet resObj=statementObj.executeQuery(sql);
            //5 处理结果
            while (resObj.next()){
                String strId=resObj.getString("class_id");
                String strName=resObj.getString("class_name");
                System.out.println(strId + "---" + strName);
            }


        }
        catch (ClassNotFoundException e){
            e.printStackTrace();
        }
        catch (SQLException e){
            e.printStackTrace();
        }finally{
            //6 释放资源
            if(statementObj!=null) {
                try{
                    statementObj.close();
                }
                catch (SQLException e){
                    e.printStackTrace();
                }

            }
            if(conObj!=null){
                try {
                    conObj.close();
                }catch (SQLException e){
                    e.printStackTrace();
                }
            }

        }
    }

    public static void testPreparedStatement(){
        Statement statementObj=null;
        Connection conObj=null;
        try{
            //1注册驱动
            /*
            static void registerDriver(Driver driver) :注册与给定的驱动程序 DriverManager 。
            写代码使用:  Class.forName("com.mysql.jdbc.Driver");
            通过查看源码发现:在com.mysql.jdbc.Driver类中存在静态代码块,加载Driver的时候会执行静态代码块
            static {
                try {
                    java.sql.DriverManager.registerDriver(new Driver());
                } catch (SQLException E) {
                    throw new RuntimeException("Can't register driver!");
                }
            }
            注意:mysql5之后的驱动jar包可以省略注册驱动的步骤。
            */
            Class.forName("com.mysql.jdbc.Driver");

            //2获取数据库连接对象 Connection
            /*
             * 方法:static Connection getConnection(String url, String user, String password)
             * 参数:
             * url:指定连接的路径
             * 语法:jdbc:mysql://ip地址(域名):端口号/数据库名称
             * 例子:jdbc:mysql://localhost:3306/mysql
             * 细节:如果连接的是本机mysql服务器,并且mysql服务默认端口是3306,则url可以简写为:jdbc:mysql://数据库名称
             * user:用户名
             * password:密码
             * */
            conObj= DriverManager.getConnection("jdbc:mysql://localhost:3306/mysql","root","root");

            //4获取执行sql语句的对象 Statement
            /*
             * 1. 获取执行sql 的对象
             * Statement createStatement()
             * PreparedStatement prepareStatement(String sql)
             * 1. boolean execute(String sql) :可以执行任意的sql 了解
		    		2. int executeUpdate(String sql) :执行DML(insert、update、delete)语句、DDL(create,alter、drop)语句
		    			* 返回值:影响的行数,可以通过这个影响的行数判断DML语句是否执行成功 返回值>0的则执行成功,反之,则失败。
		    		3. ResultSet executeQuery(String sql):执行DQL(select)语句
		       解决sql注入问题:使用PreparedStatement对象来解决
		       预编译的SQL:参数使用?作为占位符
             */
            PreparedStatement preparedStatementObj=conObj.prepareStatement("select * from t_class where class_id=? and class_name=?");
            /*
            给?赋值:
			* 方法: setXxx(参数1,参数2)
				* 参数1:?的位置编号 从1 开始
				* 参数2:?的值
            * */
            preparedStatementObj.setString(1,"1");
            preparedStatementObj.setString(2,"高一");
            ResultSet resObj=preparedStatementObj.executeQuery();
            //5 处理结果
            while (resObj.next()){
                String strId=resObj.getString("class_id");
                String strName=resObj.getString("class_name");
                System.out.println(strId + "---" + strName);
            }

        }
        catch (ClassNotFoundException e){
            e.printStackTrace();
        }
        catch (SQLException e){
            e.printStackTrace();
        }finally{
            //6 释放资源
            if(statementObj!=null) {
                try{
                    statementObj.close();
                }
                catch (SQLException e){
                    e.printStackTrace();
                }

            }
            if(conObj!=null){
                try {
                    conObj.close();
                }catch (SQLException e){
                    e.printStackTrace();
                }
            }

        }
    }
    public static void main(String[] args) throws Exception {
        //testCreateStatement();
        testPreparedStatement();

    }
}


注意:后期都会使用PreparedStatement来完成增删改查的所有操作

  1. 可以防止SQL注入
  2. 效率更高
    在这里插入图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值