热门标签 | 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);
}
}
}
在这里插入图片描述


推荐阅读
  • 本文探讨了在 SQL Server 中使用 JDBC 插入数据时遇到的问题。通过详细分析代码和数据库配置,提供了解决方案并解释了潜在的原因。 ... [详细]
  • XWiki 数据模型开发指南
    本文档不仅介绍XWiki作为一个增强版的wiki引擎,还深入探讨了其数据模型,该模型可在用户界面层面被充分利用。借助其强大的脚本能力,XWiki的数据模型支持从简单的应用到复杂的系统构建,几乎无需直接接触XWiki的核心组件。 ... [详细]
  • 本文详细介绍了如何通过RPM包在Linux系统(如CentOS)上安装MySQL 5.6。涵盖了检查现有安装、下载和安装RPM包、配置MySQL以及设置远程访问和开机自启动等步骤。 ... [详细]
  • 阿里云ecs怎么配置php环境,阿里云ecs配置选择 ... [详细]
  • JavaScript 基础语法指南
    本文详细介绍了 JavaScript 的基础语法,包括变量、数据类型、运算符、语句和函数等内容,旨在为初学者提供全面的入门指导。 ... [详细]
  • 本文介绍如何使用 Android 的 Canvas 和 View 组件创建一个简单的绘图板应用程序,支持触摸绘画和保存图片功能。 ... [详细]
  • 在项目部署后,Node.js 进程可能会遇到不可预见的错误并崩溃。为了及时通知开发人员进行问题排查,我们可以利用 nodemailer 插件来发送邮件提醒。本文将详细介绍如何配置和使用 nodemailer 实现这一功能。 ... [详细]
  • C#设计模式学习笔记:观察者模式解析
    本文将探讨观察者模式的基本概念、应用场景及其在C#中的实现方法。通过借鉴《Head First Design Patterns》和维基百科等资源,详细介绍该模式的工作原理,并提供具体代码示例。 ... [详细]
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • CentOS 7.6环境下Prometheus与Grafana的集成部署指南
    本文旨在提供一套详细的步骤,指导读者如何在CentOS 7.6操作系统上成功安装和配置Prometheus 2.17.1及Grafana 6.7.2-1,实现高效的数据监控与可视化。 ... [详细]
  • 本文档汇总了Python编程的基础与高级面试题目,涵盖语言特性、数据结构、算法以及Web开发等多个方面,旨在帮助开发者全面掌握Python核心知识。 ... [详细]
  • YB02 防水车载GPS追踪器
    YB02防水车载GPS追踪器由Yuebiz科技有限公司设计生产,适用于车辆防盗、车队管理和实时追踪等多种场合。 ... [详细]
  • 本文详细介绍了如何在C#程序运行期间防止系统进入休眠模式以及显示器关闭,提供了具体的实现代码示例,并解释了其应用场景。这不仅有助于提高程序的稳定性,还能优化能源管理。适合需要处理长时间任务(如下载或批处理)的开发者参考。 ... [详细]
  • 深入理解Lucene搜索机制
    本文旨在帮助读者全面掌握Lucene搜索的编写步骤、核心API及其应用。通过详细解析Lucene的基本查询和查询解析器的使用方法,结合架构图和代码示例,带领读者深入了解Lucene搜索的工作流程。 ... [详细]
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社区 版权所有