热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Java操作MySQL,创建JDBC工具类、使用Druid连接池技术,实现CRUD(增、删、改、查)

要求:使用JDBC创建一张表,表名student,字段包含id,姓名(username)、班级(class_and_grad

要求:使用JDBC创建一张表,表名student,字段包含id,姓名(username)、班级(class_and_grade)学号(student_number)、性别(sex)、年龄(age)、邮箱(email)。并且添加相应的约束。对表实现CRUD(注意增删改得使用。

1.创建一个module命名JDBC
2.添加资源druid.proporties
在这里插入图片描述

3.和MySQL数据库取得连接
在这里插入图片描述
在这里插入图片描述
4.配置JDBC工具类
package com.cn.zpark.utils;

import java.sql.*;

public class JDBCUtils {
// 定义数据路连接信息
private static String url = “jdbc:mysql://localhost:3306/my_druid?useSSL=false&serverTimezone=UTC&characterEncoding=UTF-8”;
private static String user = “root”;
private static String pwd = “root”;

public static Connection getConn() throws Exception {// 注册驱动Class.forName("com.mysql.jdbc.Driver");// 返回连接对象return DriverManager.getConnection(url, user, pwd);
}public static void close(Connection conn, ResultSet res, Statement... stat){try {if(res != null){res.close();}for (Statement statement : stat) {if(statement != null){statement.close();}}assert conn != null;conn.close();} catch (SQLException e) {e.printStackTrace();}
}

}

5.开始创建表student
代码:
package com.cn.zpark;

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

public class JDBCCreateTable {
public static void main(String[] args) {
// 定义连接数据库信息
String url = “jdbc:mysql://localhost:3306/my_druid?useSSL=false&serverTimezone=UTC&characterEncoding=UTF-8”;
String user = “root”;
String pwd = “root”;
Connection conn = null;
Statement stat = null;

try {// 1、注册驱动Class.forName("com.mysql.jdbc.Driver");// 2、获取连接对象conn = DriverManager.getConnection(url, user, pwd);// 3、获取statement对象stat = conn.createStatement();// 4、创建sql语句String sql = "create table student(id int primary key auto_increment, username varchar(100) not null unique," +"class_and_grade varchar(100) not null , student_number varchar(100) not null , sex varchar(10) not null, age varchar (10) not null, email varchar(100) not null unique )";// 5、执行sqlstat.execute(sql);System.out.println("创建表成功");} catch(Exception e) {e.printStackTrace();System.out.println("创建表失败,原因未知");} finally {// 6、关闭资源if(stat != null){try {stat.close();} catch (SQLException e) {e.printStackTrace();}}if(conn != null){try {conn.close();} catch (SQLException e) {e.printStackTrace();}}}
}

}

创建成功后在mysql数据库中可以查看表结构
在这里插入图片描述
6插入数据:
package com.cn.zpark;

import com.cn.zpark.utils.JDBCUtils;

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

public class JDBCInsert {
public static void main(String[] args) {
Connection conn = null;
PreparedStatement stat = null;
try {
conn = JDBCUtils.getConn();
conn.setAutoCommit(false);
String sql = “insert into student(username,class_and_grade,student_number,sex,age,email)values” +
“(‘TOM’,‘计本一班’,‘31’,‘男’,‘18’,‘tm123456@qq.com’),” +
“(‘王五’,‘计本一班’,‘32’,‘男’,‘19’,‘ww123456@qq.com’),” +
“(‘小明’,‘计本二班’,‘23’,‘女’,‘20’,‘xm123456@qq.com’),” +
“(‘张三’,‘计本一班’,‘42’,‘女’,‘21’,‘zs123456@qq.com’),” +
“(‘钱七’,‘计本二班’,‘15’,‘男’,‘19’,‘qq123456@qq.com’)”;
stat = conn.prepareStatement(sql);
stat.executeUpdate();
conn.commit();
System.out.println(“成功插入数据”);
} catch (Exception e) {
e.printStackTrace();
try {
if (conn != null) {
conn.rollback();
}
} catch (SQLException ex) {
ex.printStackTrace();
}
} finally {
JDBCUtils.close(conn, null, stat);
}
}
}
在这里插入图片描述
7.删除数据
package com.cn.zpark;

import com.cn.zpark.utils.JDBCUtils;

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

public class JDBCDelete {
public static void main(String[] args) {
Connection conn = null;
PreparedStatement stat = null;
try {
conn = JDBCUtils.getConn();
// 开启事务,关闭事务字段提交
conn.setAutoCommit(false);
String sql = “delete from student where username =‘张三’”;
// 创建预编译sql对象
stat = conn.prepareStatement(sql);
stat.executeUpdate();
// 提交事务
conn.commit();
} catch(Exception e) {
e.printStackTrace();
// 回滚事务
try {
if(conn != null){
conn.rollback();
}
} catch (SQLException ex) {
ex.printStackTrace();
}
} finally {
JDBCUtils.close(conn, null, stat);
}
}
}
在这里插入图片描述
8.修改数据:
package com.cn.zpark;

import com.cn.zpark.utils.JDBCUtils;

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

public class JDBCUpdate {
public static void main(String[] args) {
Connection conn = null;
PreparedStatement stat1 = null;
try {
conn = JDBCUtils.getConn();
// 开启事务,关闭事务字段提交
conn.setAutoCommit(false);
String sql1 = “update student set class_and_grade= ‘计本一班’ where student_number = ‘23’ or student_number = ‘15’”;
// 创建预编译sql对象
stat1 = conn.prepareStatement(sql1);
stat1.executeUpdate();
// 提交事务
conn.commit();
System.out.println(“修改数据成功!”);
} catch(Exception e) {
e.printStackTrace();
// 回滚事务
try {
if(conn != null){
conn.rollback();
}
} catch (SQLException ex) {
ex.printStackTrace();
}
} finally {
JDBCUtils.close(conn, null, stat1);
}
}
}

在这里插入图片描述
9.查询数据:
package com.cn.zpark;

import com.cn.zpark.utils.JDBCUtils;

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

public class JDBCSelect {
public static void main(String[] args) {
Connection conn = null;
PreparedStatement stat = null;
ResultSet res = null;
try {
conn = JDBCUtils.getConn();
String sql = “select id,username,class_and_grade,student_number,sex,age,email from student where username=‘TOM’ or username=‘小明’”;
// 创建预编译sql对象
stat = conn.prepareStatement(sql);
res = stat.executeQuery();
// 变量结果集
while (res.next()) {
System.out.println(res.getInt(“id”));
System.out.println(res.getString(“username”));
System.out.println(res.getString(“class_and_grade”));
System.out.println(res.getString(“student_number”));
System.out.println(res.getString(“sex”));
System.out.println(res.getString(“age”));
System.out.println(res.getString(“email”));
}
} catch (Exception e) {
e.printStackTrace();
} finally {
JDBCUtils.close(conn, res, stat);
}
}
}
在这里插入图片描述


推荐阅读
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • Mybatis拦截器实现数据权限的示例代码
    在我们日常开发过程中,通常会涉及到数据权限问题,本文主要介绍了Mybatis拦截器实现数据权限的示例代码,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 本文介绍了解决Netty拆包粘包问题的一种方法——使用特殊结束符。在通讯过程中,客户端和服务器协商定义一个特殊的分隔符号,只要没有发送分隔符号,就代表一条数据没有结束。文章还提供了服务端的示例代码。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • r2dbc配置多数据源
    R2dbc配置多数据源问题根据官网配置r2dbc连接mysql多数据源所遇到的问题pom配置可以参考官网,不过我这样配置会报错我并没有这样配置将以下内容添加到pom.xml文件d ... [详细]
  • Java自带的观察者模式及实现方法详解
    本文介绍了Java自带的观察者模式,包括Observer和Observable对象的定义和使用方法。通过添加观察者和设置内部标志位,当被观察者中的事件发生变化时,通知观察者对象并执行相应的操作。实现观察者模式非常简单,只需继承Observable类和实现Observer接口即可。详情请参考Java官方api文档。 ... [详细]
  • 数组的排序:数组本身有Arrays类中的sort()方法,这里写几种常见的排序方法。(1)冒泡排序法publicstaticvoidmain(String[]args ... [详细]
  • 面向对象之3:封装的总结及实现方法
    本文总结了面向对象中封装的概念和好处,以及在Java中如何实现封装。封装是将过程和数据用一个外壳隐藏起来,只能通过提供的接口进行访问。适当的封装可以提高程序的理解性和维护性,增强程序的安全性。在Java中,封装可以通过将属性私有化并使用权限修饰符来实现,同时可以通过方法来访问属性并加入限制条件。 ... [详细]
  • (三)多表代码生成的实现方法
    本文介绍了一种实现多表代码生成的方法,使用了java代码和org.jeecg框架中的相关类和接口。通过设置主表配置,可以生成父子表的数据模型。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • 开发笔记:Java是如何读取和写入浏览器Cookies的
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Java是如何读取和写入浏览器Cookies的相关的知识,希望对你有一定的参考价值。首先我 ... [详细]
  • 定义函数functionf(){}调用函数f();可变函数functionf(){}$f1f;$f1();匿名函数$ffunction($ ... [详细]
author-avatar
蛋狗酱_972
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有