【MySQL】Java连接MySQL数据库(封装版只需会MySQL)

news2024/9/22 1:49:13

一、准备

  1. 普通项目

如果创建的是普通的Java项目,我们需要去maven仓库下载jdbc驱动包然导入项目中就能使用,具体步骤详见MySQL数据库之Java中如何使用数据库【JDBC编程】

  1. maven项目

如果创建的项目是maven项目,我们只需在pom.xml文件里引入一组依赖即可

<dependencies>
        <!--jdbc-->
        <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.49</version>
        </dependency>
    </dependencies>

引入依赖后点击右侧的maven刷新即可

创建类导入代码

import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;

import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;

public class JDBCDemo {
     private static DataSource dataSource;
     private static String database;
     private static String password;
     private static int port = 3306;  //如果修改了端口号提供设置

     /**
      * 提供构造方法 传入操作的数据库名称 与 数据库的密码
      * @param database 数据库名
      * @param password 数据库密码
      */
     public JDBCDemo(String database,String password) throws SQLException {
          if (password == null){
               password = "";
          }

          if (database == null || database == ""){
               throw new SQLException("数据库名为空");
          }

          this.database = database;
          this.password = password;
     }

     /**
      * 如果修改了MySQL的端口号就进行设置
      * @param port
      */
     public void setPort(int port){
          this.port = port;
     }

     // 封装CRUD
     private int SQL(String sql){
          int n = 0;
          Connection connection = null;
          PreparedStatement statement = null;

          try {
               // 建立连接
               connection = DBUtil.getConnect();
               // 构造请求
               statement = connection.prepareStatement(sql);

               // 发送请求
               n = statement.executeUpdate();
          } catch (SQLException e) {
               e.printStackTrace();

          } finally {
               // 释放资源
               DBUtil.close(connection,statement,null);
          }

          return n;
     }

     public boolean insert(String sql) {
          return SQL(sql) == 1 ? true : false;
     }

     public boolean delete(String sql){
          return SQL(sql) == 1 ? true : false;
     }

     public boolean update(String sql) {
          return SQL(sql) == 1 ? true : false;
     }

     /**
      *
      * @param map 键值对:  字段名:字段对应的Java类型
      * @param sql 对应的查询sql语句
      * @return 返回M键值对:   字段名:值(需要根据具体类型进行转换)
      */
     public HashMap<String,String> select(Map<String,String> map, String sql){
          HashMap<String,String> result = new HashMap<>();
          Connection connection = null;
          PreparedStatement statement = null;
          ResultSet resultSet = null;

          try {
               // 建立连接
               connection = DBUtil.getConnect();

               // 构造sql
               statement = connection.prepareStatement(sql);

               // 处理响应
               resultSet = statement.executeQuery();
               Set<Map.Entry<String,String>> entry = map.entrySet();
               while (resultSet.next()){
                    for (Map.Entry<String ,String> x : entry) {
                         switch (x.getKey()){
                              case "int":
                                   int i = resultSet.getInt(x.getValue());
                                   result.put(x.getValue(),String.valueOf(i));
                                   break;
                              case "double":
                                   double d = resultSet.getDouble(x.getValue());
                                   result.put(x.getValue(),String.valueOf(d));
                                   break;
                              case "float":
                                   float f = resultSet.getFloat(x.getValue());
                                   result.put(x.getValue(),String.valueOf(f));
                                   break;
                              case "byte":
                                   byte b = resultSet.getByte(x.getValue());
                                   result.put(x.getValue(),String.valueOf(b));
                                   break;
                              case "char":
                                   String c = resultSet.getString(x.getValue());
                                   result.put(x.getValue(),String.valueOf(c));
                                   break;
                              case "String":
                                   result.put(x.getValue(),x.getKey());
                                   break;
                              case "long":
                                   long l = resultSet.getLong(x.getValue());
                                   result.put(x.getValue(), String.valueOf(l));
                                   break;
                              case "short":
                                   short s = resultSet.getShort(x.getValue());
                                   result.put(x.getValue(),String.valueOf(s));
                                   break;
                              default:
                                   throw new Exception("类型错误");
                         }
                    }
               }
          } catch (SQLException e) {
               e.printStackTrace();
          } catch (Exception e) {
               e.printStackTrace();
          } finally {
               DBUtil.close(connection,statement,resultSet);
          }

          return result;
     }


     /**
      * 封装与数据库连接相关的操作
      */
     private static class DBUtil {
          /**
           * 单例模式封装数据源
           * @return
           */
          private static DataSource getInstance(){
               if (dataSource == null){
                    synchronized (JDBCDemo.class){
                         if (dataSource == null){
                              dataSource = new MysqlDataSource();
                              ((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:" + JDBCDemo.port + "/"+ JDBCDemo.database + "?characterEncoding=utf8&useSSL=false");
                              ((MysqlDataSource)dataSource).setUser("root");
                              ((MysqlDataSource)dataSource).setPassword(JDBCDemo.password);
                         }
                    }
               }
               return dataSource;
          }

          /**
           * 与数据库建立连接
           * @return
           */
          private static Connection getConnect() throws SQLException {
               return getInstance().getConnection();
          }

          /**
           * 释放资源
           * @param connection
           * @param statement
           * @param resultSet
           */
          private static void close(Connection connection, PreparedStatement statement, ResultSet resultSet) {
               if(resultSet != null){
                    try {
                         resultSet.close();
                    } catch (SQLException e) {
                         e.printStackTrace();
                    }
               }

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

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

二、API

  1. 创建实例JDBCDemo传入要操作的数据库的库名以及数据库密码

  1. 如果修改过MySQL的端口号调用setPort(int)方法进行设置

  1. 进行数据库增删改查

  1. 代码示例如下

方法名

参数

说明

insert

String sql

只需传入增加数据的SQL语句即可

update

String sql

只需传入修改的SQL语句即可

delete

String sql

只需传入删除的SQL语句即可

inselect

Map<String,String> map, String sql

map是一组键值对,键是要查询数据库表的字段名,值是其对应的Java类型(如varchar(20)对应String)

public static void main(String[] args) throws SQLException {
          // 1.创建实例,传入数据库名(此处的数据库是指create database创建的数据库里与密码
          JDBCDemo jdbcDemo= new JDBCDemo("student","这里是数据库密码");

          // 2.如果修改过数据库的端口号可调用一下方法修改,默认是没有修改的
          jdbcDemo.setPort(3306);

          // 3.添加数据
          String name = "李四";int age = 10;
          jdbcDemo.insert("insert into student values(" + name + "," + age + ")");
          jdbcDemo.update("update student set age=" + 11 + "where name='李四'");
          jdbcDemo.delete("delete from student where name='张三'");

          // 获取树数据
          HashMap<String,String> tableName = new HashMap<>();
          map.put("name","String");
          map.put("age","int");
          HashMap<String,String> ret = jdbcDemo.select(map,"select * from student");
          int studentAge = Integer.parseInt(map.get("age"));
     }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/357649.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

适合初学者的超详细实用调试技巧(上)

我们日常写代码的时候&#xff0c;常常会遇到bug的情况&#xff0c;这个时候像我这样的初学者就会像无头苍蝇一样这里改改那里删删&#xff0c;为了根除这种情况&#xff0c;我最近系统学习了调试的技巧&#xff0c;我想要十分详细地讲解&#xff0c;所以大概不会一篇文章写完。…

Django入门与构建

文章目录Django入门与构建Django介绍conda切换环境(看需要)安装虚拟环境基于 virtualenv基于venvDjango项目构建Django项目安装&#xff1a;创建应用Django运行测试总结Django入门与构建 官网&#xff1a;https://www.djangoproject.com/ 博客&#xff1a;https://www.liujian…

Spring的IOC,注入问题,包括自动注入的条件和前提

1. 前言 Spring的核心技术IOC(Intorol of Converse控制反转)的实现途径是DI(dependency Insert依赖注入)。而依赖注入(DI)的实现方式又有两种&#xff0c;xml方式和注解方式。如下图所示&#xff1a; 什么是属性注入 属性注入就是在实例化对象时&#xff0c;同时向对象中的…

小米12s ultra,索尼xperia1 iv,数码相机 拍照对比

首先说明所有的测试结果和拍摄数据我放到百度网盘了(地址在结尾) 为什么做这个测试 我一直想知道现在的手机和相机差距有多大,到底差在哪儿? 先说结论: 1.1英寸的手机cmos(2022年) 6年前(2016)的入门款相机(m43画幅) 2.手机 不能换镜头,只能在特定的拍摄距离才能发挥出全…

网络安全-域名相关收集

网络安全-域名相关收集 前言 一&#xff0c;我也是初学者记录的笔记 二&#xff0c;可能有错误的地方&#xff0c;请谨慎 三&#xff0c;欢迎各路大神指教 四&#xff0c;任何文章仅作为学习使用 五&#xff0c;学习网络安全知识请勿适用于违法行为 学习网络安全知识请勿适用于…

【C#基础】C# 常用语句讲解

序号系列文章3【C#基础】C# 数据类型总结4【C#基础】C# 变量和常量的使用5【C#基础】C# 运算符总结文章目录前言语句概念1&#xff0c;迭代语句1.1 for 语句1.2 foreach 语句1.3 while 语句1.4 do 语句2&#xff0c;选择语句2.1&#xff0c;if 语句2.2&#xff0c;else 语句2.3…

Android 基础知识4-2.9 FrameLayout(帧布局)详解

一、FrameLayout&#xff08;帧布局&#xff09;概述 FrameLayout又称作帧布局&#xff0c;它相比于LinearLayout和RelativeLayout要简单很多&#xff0c;因为它的应用场景也少了很多。这种布局没有方便的定位方式&#xff0c;所有的控件都会默认摆放在布局的左上角。 示例1代…

算法队列与栈—Java版

队列、双向队列、栈 — ArrayDeque 使用双向队列ArrayDeque可以完成以上三种数据结构。队列的操作包括&#xff1a;入队、出队、返回队首元素、返回队尾元素、删除队首元素、删除队尾元素、判断空、返回队列长度。双向队列包括&#xff1a;首尾入队、首尾出队、返回首尾元素、…

【挣值分析】

名称解释 拼写解释PV计划费用&#xff0c;预估预算EV挣值&#xff0c;实际预估预算AC实际费用&#xff0c;实际花费CV成本偏差 &#xff08;EV - AC&#xff09;SV进度偏差&#xff08;EV - PV&#xff09;CPI成本绩效指数 &#xff08;EV / AC&#xff09;SPI进度绩效指数 &a…

【Kubernetes】【十】Pod详解 Pod介绍与配置

第五章 Pod详解 本章节将详细介绍Pod资源的各种配置&#xff08;yaml&#xff09;和原理。 Pod介绍 Pod结构 每个Pod中都可以包含一个或者多个容器&#xff0c;这些容器可以分为两类&#xff1a; 用户程序所在的容器&#xff0c;数量可多可少 Pause容器&#xff0c;这是每个…

Mybatis(4)之跟着老杜做一个简单的银行转账会话

这是个MVC项目&#xff0c;我不一定可以完整的实现这个项目&#xff0c;但力求把这个复现出来&#xff0c;尽量的复现细节。 第一步&#xff1a;创建数据库 表 创建表如下&#xff1a; 我们使用 int 是为了方便 然后采用 demcial&#xff0c;精确度较高 添加两个用户 然后…

JVM学习笔记二:运行时数据区概述及JVM线程

目录 概述 JVM各区域划分 JVM线程 线程的内存空间 JVM系统线程 概述 运行时数据区是JVM非常重要的组成部分&#xff0c;这一篇主要介绍运行时数据区各个区域的划分&#xff0c;以及JVM中的线程。 JVM各区域划分 学习JVM&#xff0c;必须牢记下图各个区域的分类&#xff…

【5G RRC】5G系统消息SIB2介绍

博主未授权任何人或组织机构转载博主任何原创文章&#xff0c;感谢各位对原创的支持&#xff01; 博主链接 本人就职于国际知名终端厂商&#xff0c;负责modem芯片研发。 在5G早期负责终端数据业务层、核心网相关的开发工作&#xff0c;目前牵头6G算力网络技术标准研究。 博客…

九龙证券|动力锂离子电池的能量密度可达多少?

现在&#xff0c;我国车用动力锂电池技能道路挑选的是与美国相同的磷酸铁锂道路。毫无疑问&#xff0c;磷酸铁锂离子电池有着许多优势&#xff1a;稳定性高、价格相对便宜&#xff0c;然而其能量密度&#xff08;能量密度更大&#xff0c;才能更好地解决路程问题&#xff09;提…

RabbitMQ 入门到应用 ( 五 ) 基本应用

6.更多应用 6.1.AmqpAdmin 工具类 可以通过Spring的Autowired 注入 AmqpAdmin 工具类 , 通过这个工具类创建 队列, 交换机及绑定 import org.springframework.amqp.core.AmqpAdmin; import org.springframework.amqp.core.Binding; import org.springframework.amqp.core.Di…

linux xargs 删除名字中包含某字符串的文件

xargs的作用 格式化输出 可以把多行文本变成一行&#xff0c;或者指定行数和列数。每一列用空格作分隔符号。 test.txt中的内容 例子1&#xff1a; 用xargs格式化输出后,多行变成了一行&#xff0c;而且多个空格变成了一个空格。 cat test|xargs例子2&#xff1a; 当然也可…

go size class 内存块思考

浏览到的一篇文章&#xff0c;让我也有机会反思一下 go 内存管理。网络上&#xff0c;go 内存管理方面的介绍挺多的&#xff0c;面试的时候&#xff0c;偶尔也会被问到内存管理。 而且&#xff0c;从 go1.15 到 go1.16 在 size class 上引入了新的内存块&#xff0c;能直观的看…

信奥一本通1365

1365&#xff1a;FBI树(fbi) 时间限制: 1000 ms 内存限制: 65536 KB 提交数: 6443 通过数: 4366 【题目描述】 我们可以把由“0”和“1”组成的字符串分为三类&#xff1a;全“0”串称为B串&#xff0c;全“1”串称为I串&#xff0c;既含“0”又含“1”的串则称为…

C语言——动态内存管理(详解)

1.动态内存管理存在的意义 在前面的C语言的学习中&#xff0c;我们已经掌握的空间开辟的方式有如下两种 int i 0; //开辟了4字节大小的空间存放i int arr[5] {0}; //开辟了20字节的空间存放数组arr这样开辟空间有两个显著的特点&#xff1a; 1、每次开辟空间的大小都是固定…

K8S集群将Docker切换到Containerd

文章目录1. 开启节点维护1.1 将节点设置成不可调度1.2 驱逐节点上的 Pod1.3 停止相关服务2. 升级到 containerd2.1 安装 containerd2.2 调整 containerd 配置2.3 修改 kubelet 启动配置参数3. 重启节点服务4. 验证升级后的节点5. 容器管理工具5.1 容器管理命令行工具对比5.2 cr…