您的位置:

Java数据库连接

在开发过程中,我们经常需要在程序中访问数据库,因此数据库连接是非常重要的一个环节。在Java中,我们可以通过一些常用的API来连接数据库,并进行数据的增删改查等操作。

一、JDBC

JDBC(Java Database Connectivity)是Java连接数据库最基本的API,它提供了访问不同数据库的标准方法。

以下是一个简单的Java程序,使用JDBC连接数据库:

import java.sql.*;

public class JdbcDemo {
    static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";
    static final String DB_URL = "jdbc:mysql://localhost:3306/myDB";
    static final String USER = "root";
    static final String PASS = "123456";

    public static void main(String[] args) {
        Connection conn = null;
        Statement stmt = null;
        try {
            // 注册 JDBC 驱动器
            Class.forName(JDBC_DRIVER);

            // 打开一个连接
            conn = DriverManager.getConnection(DB_URL, USER, PASS);

            // 执行查询
            stmt = conn.createStatement();
            String sql = "SELECT id, name FROM user";
            ResultSet rs = stmt.executeQuery(sql);

            // 处理结果集
            while (rs.next()) {
                int id = rs.getInt("id");
                String name = rs.getString("name");

                System.out.println("ID: " + id + ", Name: " + name);
            }

            // 关闭结果集,语句和连接
            rs.close();
            stmt.close();
            conn.close();

        } catch (SQLException se) {
            se.printStackTrace();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            try {
                if (stmt != null) stmt.close();
            } catch (SQLException se2) {
            }
            try {
                if (conn != null) conn.close();
            } catch (SQLException se) {
                se.printStackTrace();
            }
        }
        System.out.println("Goodbye!");
    }
}

上述代码连接MySQL数据库,并执行了一个查询操作,将结果输出到控制台。在使用JDBC连接数据库时,需要注意以下几点:

1、需要导入JDBC驱动,可以从相应数据库提供商处下载;

2、需要通过DriverManager注册驱动;

3、需要通过Connection创建连接;

4、需要通过Statement或PreparedStatement执行SQL语句;

5、需要注意资源的释放。

二、Spring JDBC

Spring JDBC是在JDBC基础上进行封装的一个框架,它为开发者提供了一种更加简单易用的方式来访问数据库。Spring JDBC以类似于JdbcTemplate的模板方式来操作,减少了数据连接和关闭的代码量。

以下是一个简单的Java程序,使用Spring JDBC连接数据库:

import javax.sql.DataSource;
import org.springframework.jdbc.core.JdbcTemplate;

public class SpringJdbcDemo {
    private JdbcTemplate jdbcTemplate;

    public void setDataSource(DataSource dataSource) {
        this.jdbcTemplate = new JdbcTemplate(dataSource);
    }

    public void query() {
        String sql = "SELECT id, name FROM user";
        jdbcTemplate.query(sql, (rs, rowNum) -> new User(
                        rs.getInt("id"),
                        rs.getString("name")
                )
        ).forEach(user -> {
            System.out.println(user.toString());
        });
    }
}

上述代码首先将DataSource传入JdbcTemplate,然后使用JdbcTemplate执行了一个查询操作,将结果输出到控制台。在使用Spring JDBC连接数据库时,需要注意以下几点:

1、需要配置数据源;

2、需要通过JdbcTemplate操作数据库;

3、需要注意SQL语句中占位符的使用方式;

4、需要定义结果集的映射方式。

三、MyBatis

MyBatis是一款优秀的数据持久层框架,它将SQL语句与Java代码解耦,使得开发者可以更加方便地进行数据库操作。MyBatis不同于JDBC和Spring JDBC,它不需要开发者编写SQL语句和结果集的映射,而是通过配置文件进行管理。

以下是一个简单的Java程序,使用MyBatis连接数据库:

import java.io.IOException;
import java.io.InputStream;
import java.util.List;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

public class MybatisDemo {
    public static void main(String[] args) throws IOException {
        String resource = "mybatis-config.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        SqlSession sqlSession = sqlSessionFactory.openSession();

        try {
            List userList = sqlSession.selectList("UserMapper.selectAll");
            for (User user : userList) {
                System.out.println(user.toString());
            }
        } finally {
            sqlSession.close();
        }
    }
}

  

上述代码通过读取mybatis-config.xml配置文件,生成SqlSessionFactory,然后通过SqlSessionFactory打开SqlSession,执行用户查询操作,并输出结果到控制台。在使用MyBatis连接数据库时,需要注意以下几点:

1、需要配置SqlSessionFactory;

2、需要在MyBatis的Mapper配置文件中定义SQL语句;

3、需要定义结果集对应的Java对象。

四、总结

通过本文,我们了解了Java连接数据库的三种方式:JDBC、Spring JDBC和MyBatis。在实际项目开发中,我们需要根据项目需求来选择合适的框架进行使用,从而提高开发效率和减少代码量。

连接mysql数据库笔记1(如何连接数据库mysql)

2022-11-10
jsp数据库笔记,jsp写入数据库

本文目录一览: 1、怎么用jsp连接mysql数据库 2、jsp中怎么使用数据库 3、JSP 从数据库中如何取得图片的路径? 怎么用jsp连接mysql数据库 一. 数据库的连接和操作笔记:1.初始化

2023-12-08
重学java笔记,java笔记总结

2022-11-23
jsp使用java连接数据库(jsp连接数据库的方法)

本文目录一览: 1、怎么使用JAVA连接数据库? 2、怎么用jsp连接mysql数据库 3、在JSP页面中实现连接数据库与在Java程序中实现连接数据库有什么区别? 4、java 中 怎样将JSP页面

2023-12-08
Java数据库连接,java 连接数据库

2023-01-04
java学习笔记(java初学笔记)

2022-11-14
发篇java复习笔记(java课程笔记)

2022-11-09
数据库与java连接,数据库与java建立连接

2022-12-01
java笔记,大学java笔记

2022-11-28
数据库连接java,数据库连接java登录界面

2022-12-02
java与数据库连接篇,数据库和java怎么连接

2022-11-21
jdbc连接mysql数据库时(JDBC数据库连接)

2022-11-11
java笔记,尚硅谷java笔记

2022-12-01
Java连接数据库

2023-05-11
java连接数据库基本步骤(java数据库连接方式)

2022-11-11
Java连接数据库

2023-05-11
java连接数据库,java连接数据库实现登录

2023-01-09
jsp连接mysql数据库,jsp连接mysql数据库教程

2022-11-30
java连接数据库之mysql,连接java和数据库

2022-11-18
印象笔记记录java学习(Java成长笔记)

2022-11-12