位置: IT常识 - 正文

JDBC 连接 MySQL(jdbc连接mysql数据库不成功)

编辑:rootadmin
JDBC 连接 MySQL

推荐整理分享JDBC 连接 MySQL(jdbc连接mysql数据库不成功),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:jdbc连接mysql数据库不成功,jdbc连接mysql实现增删改查,jdbc连接mysql数据库不成功,jdbc连接mysql配置文件,jdbc连接mysql配置文件,jdbc连接mysql配置文件,jdbc连接MySQL步骤,jdbc连接MySQL代码,内容如对您有帮助,希望把文章链接给更多的朋友!

哈喽~大家好,这次我们来看看 JDBC 如何 连接 MySQL.

目录

一、开头

二、介绍

1、JDBC 的概念

2、JDBC 的功能

3、JDBC 的常用接口和类

三、数据库的创建(MySQL)

1、连接 MySQL 

(1)、注册驱动

(2)、获取连接

(3)、获取执行者连接

(4)、执行 SQL 语句,并接受结果

(5)、处理结果

(6)、释放资源

四、对 MySQL 进行增删改查

1、准备工作

五、JDBC 实践操作

1、根据 id 获取信息

2、添加信息

3、修改信息

4、删除信息

六、代码优化

七、JSP 连接 MYSQL

1、查询操作

2、增加操作

3、修改操作

4、删除操作


一、开头

       首先如何下载安装 MySQL (链接),如何下载安装 SQLyog (链接),以及怎样下载 mysql-connector-java.jar(链接),可以看看这三位大佬的,这里操作数据库用的是  SQLyog  这款软件。

       好了之后,我们用 idea 创建项目,记得要勾选 Web应用程序。

        然后将 mysql-connector-java.jar 放入在 WEB - INF 里面的 lib 里面(如果没有就自己创建一个,记得要打包文件)

二、介绍1、JDBC 的概念

        JDBC 是 Java DataBase Connectivity (Java 数据连接)技术的简称,是一种可用于执行 SQL 语句的 Java API。它由一些 java 语言编写的类和接口组成;程序员通过使用 jdbc 可以方便地将 SQL 语句传送给几乎任何一种数据库。

2、JDBC 的功能

(1) 与数据库建立连接。 (2) 向数据库发送 SQL 语句并执行这些语句。 (3) 处理数据返回的结果。

3、JDBC 的常用接口和类

(1) Driver 接口:加载驱动程序。 (2) DriverManager 类:装人所需的 JDBC 驱动程序,编程时调用它的方法来创建连接。 (3) Connection 接口:编程时使用该类对象创建 Statement 对象。 (4) Statement 接口:编程时使用该类对象得到 ResultSet 对象。 (5) ResultSet 类:负责保存 Statement 执行后所产生的查询结果。

工作原理图

三、数据库的创建(MySQL)

右击 root@localhost 创建 db1 (注:基字符集一定要 uft8,别问为什么,本人因为这被折磨了半小时)输入名称 user

 或者用 sql 语句创建

CREATE DATABASE db1;USE db1;CREATE TABLE `user`(`id` INT,`name` VARCHAR(30));INSERT INTO `user` VALUES (1,'张一'),(2,'张二'),(3,'张三'),(4,'张四'),(5,'张五');1、连接 MySQL (1)、注册驱动Class.forName("com.mysql.cj.jdbc.Driver");(2)、获取连接Connection com = DriverManager.getConnection("jdbc:mysql://10.16.158.90:3306/db1", "root", "123456");(3)、获取执行者连接Statement stat = com.createStatement();(4)、执行 SQL 语句,并接受结果String sql = "SELECT * FROM user";ResultSet rs = stat.executeQuery(sql);(5)、处理结果while (rs.next()){ System.out.println(rs.getInt("id") + "\t" + rs.getString("name"));}(6)、释放资源com.close();stat.close();com.close();

代码连接起来

package com.text.jdbc;import java.sql.*;public class jbdc { public static void main(String[] args) throws Exception { Class.forName("com.mysql.cj.jdbc.Driver"); Connection com = DriverManager.getConnection("jdbc:mysql://10.16.158.90:3306/db1", "root", "123456"); // DriverManager 注册驱动 // Connection 数据库连接对象 url(指定连接的路径 语法:“jdbc:mysql://ip地址:端口号/数据库名称”) Statement stat = com.createStatement(); //执行 sql 语句的对象 String sql = "SELECT * FROM user"; ResultSet rs = stat.executeQuery(sql); // 执行 增删改查 (DML)语句用 int executeUpdate(Sting sql); // 执行 DQL 语句 ResultSet executeQuery(String sql); // 对象释放 void close(); while (rs.next()){ System.out.println(rs.getInt("id") + "\t" + rs.getString("name")); } com.close(); stat.close(); com.close(); }}

这里有个小细节,在步骤一中,注册驱动那,如果忘了驱动名或者敲错了,可以在 lib -> mysql-connector-java.jar -> jdbc -> Driver 里面查看

点击运行,控制台读取数据库的数据,完成连接。 

四、对 MySQL 进行增删改查1、准备工作

       首先我们创建好数据库(名为db1)数据表(名为student),并添加好数据 (这是我们的总表),如图:

       在前面我们用 jdbc 类 打印出所有的数据表信息,这里我们换一种方式,升级版

JDBC 连接 MySQL(jdbc连接mysql数据库不成功)

       这里我们创建 controller包(里面有 StudentController 类)、dao包(里面有 StudentDao 接口、StudentDaoImpl 类)、daomian 包(里面有 Student 类)、service 包(里面有 StudentService 接口、StudentServiceImpl 类),如图,并写入代码:

StudentController 类:

package com.inxzw.domain.controller;import com.inxzw.domain.domain.Student;import com.inxzw.domain.service.StudentService;import com.inxzw.domain.service.StudentServiceImpl;import org.testng.annotations.Test;import java.util.ArrayList;public class StudentController { private StudentService service = new StudentServiceImpl(); @Test public void findAll(){ ArrayList<Student> list = service.findAll(); for (Student stu : list){ System.out.println(stu); } } public void findById(){ }}

 StudentDao 接口:

package com.inxzw.domain.dao;import com.inxzw.domain.domain.Student;import java.util.ArrayList;public interface StudentDao { // 查询所有学生信息 public abstract ArrayList<Student> findAll(); //获取id public abstract Student findById(Integer id);// 新增信息 public abstract int insert(Student stu);// 修改信息 public abstract int update(Student stu);// 删除信息 public abstract int delete(Integer id);}StudentDaoImpl类:package com.inxzw.domain.dao;import com.inxzw.domain.domain.Student;import java.sql.*;import java.util.ArrayList;import java.util.Date;public class StudentDaoImpl implements StudentDao{ @Override public ArrayList<Student> findAll(){ Connection com = null; Statement stat = null; ResultSet rs = null; ArrayList<Student> list = new ArrayList<>(); try { Class.forName("com.mysql.cj.jdbc.Driver"); com = DriverManager.getConnection("jdbc:mysql://10.16.158.90:3306/db1", "root", "123456"); stat = com.createStatement(); String sql = "SELECT * FROM student"; rs = stat.executeQuery(sql); while (rs.next()){// System.out.println(rs.getInt("id") + "\t" + rs.getString("name")); Integer sid = rs.getInt("sid"); String name = rs.getString("name"); Integer age = rs.getInt("age"); Date birthday = rs.getDate("birthday"); Student stu = new Student(sid,name,age,birthday); list.add(stu); } }catch (Exception e){ e.printStackTrace(); }finally { if (com != null) { try { com.close(); } catch (SQLException e) { e.printStackTrace(); } } if (stat != null) { try { stat.close(); } catch (SQLException e) { e.printStackTrace(); } } if (rs != null) { try { rs.close(); } catch (SQLException e) { e.printStackTrace(); } } } return list; } @Override public Student findById(Integer id) { return null; } @Override public int insert(Student stu) { return 0; } @Override public int update(Student stu) { return 0; } @Override public int delete(Integer id) { return 0; }}Student 类:package com.inxzw.domain.domain;import java.util.Date;public class Student { private Integer sid; private String name; private Integer age; private Date birthday; public Student(Integer sid, String name, Integer age, Date birthday) { this.sid = sid; this.name = name; this.age = age; this.birthday = birthday; } public Integer getSid() { return sid; } public void setSid(Integer sid) { this.sid = sid; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } @Override public String toString() {//打印 return "Student{" + "sid=" + sid + ", name='" + name + '\'' + ", age=" + age + ", birthday=" + birthday + '}'; }}StudentService 接口:package com.inxzw.domain.service;import com.inxzw.domain.domain.Student;import java.util.ArrayList;public interface StudentService { public abstract ArrayList<Student> findAll(); public abstract Student findById(Integer id); public abstract int insert(String stu); public abstract int update(Student stu); public abstract int delete(Integer id);}StudentServiceImpl 类:package com.inxzw.domain.service;import com.inxzw.domain.dao.StudentDao;import com.inxzw.domain.dao.StudentDaoImpl;import com.inxzw.domain.domain.Student;import java.util.ArrayList;public class StudentServiceImpl implements StudentService{ private StudentDao dao = new StudentDaoImpl(); public ArrayList<Student> findAll(){ return dao.findAll(); } public Student findById(Integer id){ return null; } @Override public int insert(String stu) { return 0; } @Override public int update(Student stu) { return 0; } @Override public int delete(Integer id) { return 0; }}

       在 StudentController 类(控制类) ,运行 findAll() ,记得要加 @Text ,点击运行。完成查询所有信息。

五、JDBC 实践操作1、根据 id 获取信息

我们可以通过 id 来获取属性,eg:通过 id 为 5 来查询元组。代码如下:

StudentDaoImpl 类:

public Student findById(Integer id) { Student stu = new Student(); Connection com = null; Statement stat = null; ResultSet rs = null; ArrayList<Student> list = new ArrayList<>(); try { Class.forName("com.mysql.cj.jdbc.Driver"); com = DriverManager.getConnection("jdbc:mysql://10.16.158.90:3306/db1", "root", "123456"); stat = com.createStatement(); String sql = "SELECT * FROM student WHERE sid = '"+id+"' "; rs = stat.executeQuery(sql); while (rs.next()){// System.out.println(rs.getInt("id") + "\t" + rs.getString("name")); Integer sid = rs.getInt("sid"); String name = rs.getString("name"); Integer age = rs.getInt("age"); Date birthday = rs.getDate("birthday"); stu.setSid(sid); stu.setName(name); stu.setAge(age); stu.setBirthday(birthday); } }catch (Exception e){ e.printStackTrace(); }finally { if (com != null) { try { com.close(); } catch (SQLException e) { e.printStackTrace(); } } if (stat != null) { try { stat.close(); } catch (SQLException e) { e.printStackTrace(); } } if (rs != null) { try { rs.close(); } catch (SQLException e) { e.printStackTrace(); } } } return stu; }StudentServiceImpl 类: public Student findById(Integer id){ return dao.findById(id); }StudentController 类: public void findById(){ Student stu = service.findById(4);//查询3号记录 System.out.println(stu); }

        点击运行,完成查询。

2、添加信息

StudentDaoImpl 类:

@Override public int insert(Student stu) { Connection com = null; Statement stat = null; int result = 0; try { Class.forName("com.mysql.cj.jdbc.Driver"); com = DriverManager.getConnection("jdbc:mysql://10.16.158.90:3306/db1", "root", "123456"); stat = com.createStatement(); Date d = stu.getBirthday(); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); String birthday = sdf.format(d); String sql = "INSERT INTO student VALUES ('"+stu.getSid()+"','"+stu.getName()+"','"+stu.getAge()+"','"+birthday+"')"; result = stat.executeUpdate(sql); }catch (Exception e){ e.printStackTrace(); }finally { if (com != null) { try { com.close(); } catch (SQLException e) { e.printStackTrace(); } } if (stat != null) { try { stat.close(); } catch (SQLException e) { e.printStackTrace(); } } } return result; }

StudentServiceImpl 类:

public int insert(Student stu) { return dao.insert(stu); }StudentController 类: public void insert(){ Student stu = new Student(9, "张九", 29, new Date()); int result = service.insert(stu); if (result != 0){ System.out.println("添加成功"); }else { System.out.println("添加失败"); } }

         点击运行,显示出添加成功,我们用 findAll() 来查看表信息,完成添加。

3、修改信息

StudentDaoImpl 类:

public int update(Student stu) { Connection com = null; Statement stat = null; int result = 0; try { Class.forName("com.mysql.cj.jdbc.Driver"); com = DriverManager.getConnection("jdbc:mysql://10.16.158.90:3306/db1", "root", "123456"); stat = com.createStatement(); Date d = stu.getBirthday(); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); String birthday = sdf.format(d); String sql = "UPDATE student SET sid = '"+stu.getSid()+"', name = '"+stu.getName()+"', age = '"+stu.getAge()+"',birthday = '"+birthday+"' WHERE sid = '"+stu.getSid()+"'"; result = stat.executeUpdate(sql); }catch (Exception e){ e.printStackTrace(); }finally { if (com != null) { try { com.close(); } catch (SQLException e) { e.printStackTrace(); } } if (stat != null) { try { stat.close(); } catch (SQLException e) { e.printStackTrace(); } } } return result; }

StudentServiceImpl 类:

public int update(Student stu) { return dao.update(stu); }

StudentController 类:

@Test public void update(){ Student stu = service.findById(5); stu.setName("张五点五"); int result = service.update(stu); if (result != 0){ System.out.println("修改成功"); }else { System.out.println("修改失败"); } }

        点击运行,显示出修改成功,我们用 findAll() 来查看表信息,完成修改。

4、删除信息

StudentDaoImpl 类:

public int delete(Integer id) { Connection com = null; Statement stat = null; int result = 0; try { Class.forName("com.mysql.cj.jdbc.Driver"); com = DriverManager.getConnection("jdbc:mysql://10.16.158.90:3306/db1", "root", "123456"); stat = com.createStatement(); String sql = "DELETE FROM student WHERE sid = '"+id+"'"; result = stat.executeUpdate(sql); }catch (Exception e){ e.printStackTrace(); }finally { if (com != null) { try { com.close(); } catch (SQLException e) { e.printStackTrace(); } } if (stat != null) { try { stat.close(); } catch (SQLException e) { e.printStackTrace(); } } } return result; }

StudentServiceImpl 类:

public int delete(Integer id) { return dao.delete(id); }

StudentController 类:

@Test public void delete(){ int result = service.delete(5); if (result != 0){ System.out.println("删除成功"); }else { System.out.println("删除失败"); } }

       点击运行,显示出删除成功,我们用 findAll() 来查看表信息,完成删除(我们删除了张五点五那一行信息)。

六、代码优化

       在这里我们完成了对数据表进行了增删改查操作,最后来看 StudentDaoImpl 类中发现我们已经写了 300 多行代码,而且我们还写了,非常多的重复代码,效率非常的底,所以为了减少代码量,这里我们需要优化。

       我们创建一个新的包名叫 utils ,新建类 JDBCutils,然后创建配置文件 config.properties

           在 JDBCutils 类里面:“构造私有方法、

本文链接地址:https://www.jiuchutong.com/zhishi/299145.html 转载请保留说明!

上一篇:大学生网页设计制作作业实例代码 (全网最全,建议收藏) HTML+CSS+JS(大学生网页设计大赛)

下一篇:【python量化】大幅提升预测性能,将NSTransformer用于股价预测(python 量化)

  • 借呗可以关闭吗(花呗借呗可以关闭吗)

    借呗可以关闭吗(花呗借呗可以关闭吗)

  • 戴尔售后维修服务网点(戴尔售后维修服务站)

    戴尔售后维修服务网点(戴尔售后维修服务站)

  • 淘宝证书错误怎么办(淘宝证书风险怎么解决)

    淘宝证书错误怎么办(淘宝证书风险怎么解决)

  • 如何关闭qq空间的消息提示(如何关闭qq空间不看别人的空间)

    如何关闭qq空间的消息提示(如何关闭qq空间不看别人的空间)

  • 微信怎么加人不会异常(微信怎么加人不容易被限制)

    微信怎么加人不会异常(微信怎么加人不容易被限制)

  • 下载谷歌浏览器后为什么打不开(下载谷歌浏览器官网)

    下载谷歌浏览器后为什么打不开(下载谷歌浏览器官网)

  • 小米服务框架关闭有影响吗(小米服务框架关掉会有事吗)

    小米服务框架关闭有影响吗(小米服务框架关掉会有事吗)

  • 苹果耳机三代怎么充电(苹果耳机三代怎么接电话)

    苹果耳机三代怎么充电(苹果耳机三代怎么接电话)

  • 手机切屏是什么意思(手机切屏是什么意思视频)

    手机切屏是什么意思(手机切屏是什么意思视频)

  • ips后面加个lgd什么意思(lgd ips ah ips)

    ips后面加个lgd什么意思(lgd ips ah ips)

  • 为什么微信收不到文件(为什么微信收不了红包和转账)

    为什么微信收不到文件(为什么微信收不了红包和转账)

  • xsmax都是英特尔基带吗(xsmax 英特尔)

    xsmax都是英特尔基带吗(xsmax 英特尔)

  • vivo手机拉黑对方还能收到信息吗(vivo手机拉黑对方)

    vivo手机拉黑对方还能收到信息吗(vivo手机拉黑对方)

  • 手机关机后qq多久下线(手机关机qq多久会离线)

    手机关机后qq多久下线(手机关机qq多久会离线)

  • 拍雨景用多大光圈(拍雨景用多大光圈好)

    拍雨景用多大光圈(拍雨景用多大光圈好)

  • 滴答出行车主认证条件(滴答出行车主认证收费吗?)

    滴答出行车主认证条件(滴答出行车主认证收费吗?)

  • rpc和restful的区别(rpc和restful的优缺点)

    rpc和restful的区别(rpc和restful的优缺点)

  • 1050ti和1050差多少(1050ti对比1050差多少)

    1050ti和1050差多少(1050ti对比1050差多少)

  • 已经发过的朋友圈还能设置权限吗(已经发过的朋友圈怎么改可见范围)

    已经发过的朋友圈还能设置权限吗(已经发过的朋友圈怎么改可见范围)

  • 苹果7 plus支持无线充电吗(苹果7 plus带不带无线充电)

    苹果7 plus支持无线充电吗(苹果7 plus带不带无线充电)

  • realme是红米吗(realme和红米是什么关系)

    realme是红米吗(realme和红米是什么关系)

  • 如何数字权利激活Windows11系统?Win11数字权利激活图文教程(数字权利服务如何打开)

    如何数字权利激活Windows11系统?Win11数字权利激活图文教程(数字权利服务如何打开)

  • Win11任务管理器不显示GPU怎么办?三种方法解决(win11任务管理器卡死没响应)

    Win11任务管理器不显示GPU怎么办?三种方法解决(win11任务管理器卡死没响应)

  • js数组forEach方法的使用(js数组方法filter)

    js数组forEach方法的使用(js数组方法filter)

  • 企业合并债权如何处理
  • 购进固定资产的安装费计入原值吗?
  • 出口货物如何申报
  • 经营者个人所得税申报
  • 个税哪种申报方式计税最好
  • 自然人独资公司有章程吗
  • 小规模纳税人购置税控设备
  • 一般纳税人能否开3%的普票
  • 党组织专项经费项社区服务队项目简介
  • 员工工资可以计入在建工程吗
  • 事业单位自筹事业人员
  • 月工资和账户工资区别
  • 文化建设费的征收标准
  • 递延和摊销
  • 固定资产折旧计提完毕怎么处理
  • 业务宣传费和广告费计入什么科目
  • 租金返还方式销售
  • 食堂伙食费账务处理
  • 差旅费报销单填写模板
  • 个人购买余额宝安全吗?
  • 贷款服务开票开具要求
  • 核定征收如何做账务处理
  • 华为折叠手机mateX5价格
  • linux命令-a
  • windows无法访问共享文件夹
  • 收到其他公司的投资款计入什么科目
  • 品牌转让怎么写
  • php实验步骤
  • WordPress置顶文章的相关PHP函数小结
  • window10下载cad2014
  • 总公司欠分公司的借款可以计提坏账
  • wifi出现感叹号上不了网怎么办
  • 固定资产增值税税率
  • 高端显卡排名
  • 公司其他费用包括哪些费用
  • php的get
  • 劳务费支出计入什么科目?
  • php写文件函数
  • 离职补偿金的会计实务处理
  • vue 的watch
  • 乌尤尼盐沼的演化过程
  • uni-swiper-dot
  • javaweb购物车设计报告
  • php 7.4
  • 命令行延时
  • 医疗保险合同印花税怎么交
  • java 代码简洁
  • 小规模教育培训怎样纳税
  • 可以公账户给私人转账吗
  • 交强险还用开车去吗
  • 售后回租会计准则
  • 某首饰商城为增值税一般纳税人,2021年1月发生以下业务
  • 赠品没发票
  • 企业筹建期间开办费计入
  • 旅游,饮食业会议内容
  • 微软新品发布
  • 使用http_load来给Linux系统的服务器做压力测试
  • redhat语言设置中文
  • mac系统小技巧
  • win7修改系统版本
  • ubuntu kde gnome
  • securecrt设置英文
  • 安装和配置eclipse集成开发环境
  • 微软报错是什么意思
  • win101909的02累积更新
  • win8任务栏点击没反应
  • js中创建函数的方法
  • json查询语句
  • Python读取Excel文件需要什么
  • Node.js中的construct
  • android怎么学
  • 同一内容复制到多个单元格
  • javascript高级程序设计电子书
  • jquery easyui 教程
  • 贵州省电子税务局操作手册
  • 高速公路过路费一公里多少钱
  • 车价36万保险一般多少钱
  • 城市基础设施配套费由哪个部门收取
  • 有发票代码和发票号码能下载到电子发票吗
  • 广东省税务机关规定小额零售需开发票吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设