位置: 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 量化)

  • 苹果13图标大小怎么调(苹果13图标大小为什么不能更改)

    苹果13图标大小怎么调(苹果13图标大小为什么不能更改)

  • 华为nova6手机变黑白怎么调过来(华为nova6手机变成灰色怎么恢复)

    华为nova6手机变黑白怎么调过来(华为nova6手机变成灰色怎么恢复)

  • 抖音反馈后要等待多久有回复(抖音反馈成功是什么意思)

    抖音反馈后要等待多久有回复(抖音反馈成功是什么意思)

  • 苹果xsmax多少厘米(苹果xsmax多长度多少厘米)

    苹果xsmax多少厘米(苹果xsmax多长度多少厘米)

  • 手机为什么没法设来电转接(手机为什么没法超级快充了)

    手机为什么没法设来电转接(手机为什么没法超级快充了)

  • 苹果11怎么下载东西(苹果11怎么下载不了app软件)

    苹果11怎么下载东西(苹果11怎么下载不了app软件)

  • 抖音极速版跟抖音短视频有什么区别(抖音极速版跟抖音是一样的吗)

    抖音极速版跟抖音短视频有什么区别(抖音极速版跟抖音是一样的吗)

  • 微信打开网页弹出广告(微信打开网页闪退是什么原因)

    微信打开网页弹出广告(微信打开网页闪退是什么原因)

  • u盘芯片坏了能恢复资料吗(u盘芯片坏了能开机吗)

    u盘芯片坏了能恢复资料吗(u盘芯片坏了能开机吗)

  • 路由器桥接会影响网速吗(路由器桥接影响主路由网速吗)

    路由器桥接会影响网速吗(路由器桥接影响主路由网速吗)

  • 小米平板闪烁解决办法(小米平板闪烁解不开锁)

    小米平板闪烁解决办法(小米平板闪烁解不开锁)

  • 苹果xmax支持快充吗(xmax支持快充嘛)

    苹果xmax支持快充吗(xmax支持快充嘛)

  • 怎么传视频给别人(怎么传视频给别的手机)

    怎么传视频给别人(怎么传视频给别的手机)

  • 快手号被注销了怎么找回来(快手号被注销了,还能重新申请吗?)

    快手号被注销了怎么找回来(快手号被注销了,还能重新申请吗?)

  • 华为手机怎么设置微信来信息不显示内容(华为手机怎么设置下面的三个功能键)

    华为手机怎么设置微信来信息不显示内容(华为手机怎么设置下面的三个功能键)

  • 手机上的压缩包是啥(手机上的压缩包是什么)

    手机上的压缩包是啥(手机上的压缩包是什么)

  • 苹果11第一次用咋设置(苹果11第一次用充电多久)

    苹果11第一次用咋设置(苹果11第一次用充电多久)

  • 手机怎么传软件到电视(手机怎么传软件到另一个手机)

    手机怎么传软件到电视(手机怎么传软件到另一个手机)

  • 共享单车的好处(共享单车的好处和坏处)

    共享单车的好处(共享单车的好处和坏处)

  • 苹果6plus找不到录屏(苹果6plus找不到更新包怎么回事)

    苹果6plus找不到录屏(苹果6plus找不到更新包怎么回事)

  • 抖音自己看加浏览量吗(抖音自己看自己视频加浏览量吗)

    抖音自己看加浏览量吗(抖音自己看自己视频加浏览量吗)

  • 电脑下载软件如何避免附带软件(电脑下载软件如何放在D盘)

    电脑下载软件如何避免附带软件(电脑下载软件如何放在D盘)

  • 华为笔记本13与x的对比(华为笔记本13与13s哪个好)

    华为笔记本13与x的对比(华为笔记本13与13s哪个好)

  • 微信主界面怎么换图片(微信主界面怎么换皮肤)

    微信主界面怎么换图片(微信主界面怎么换皮肤)

  • 手机怎样退出炫彩桌面(手机上怎么退出)

    手机怎样退出炫彩桌面(手机上怎么退出)

  • 快手播放量上不去是怎么回事(快手播放量上不去是被限流了吗)

    快手播放量上不去是怎么回事(快手播放量上不去是被限流了吗)

  • 华为支持5g网络的手机(华为哪款手机支持5g)

    华为支持5g网络的手机(华为哪款手机支持5g)

  • airpod1和2的区别(airpor1和2的区别)

    airpod1和2的区别(airpor1和2的区别)

  • 应交增值税月末出现借方余额怎么处理
  • 旅游业成本具体有哪些
  • 消费税应该怎么缴纳
  • 税务免抵调库是什么意思
  • 未认证待抵扣进项税重分类
  • 住宿报销是开普票还是专票
  • 非关联企业之间无偿借款要交税嘛
  • 红字发票信息表需要盖章吗
  • 购买车位需要交哪些税
  • 汇算清缴亏损在后期弥补时怎么做会计处理?
  • 银联交易手续费
  • 增资扩股如何操作
  • 金税三期如何报个税
  • 增值税进项税已转出后能否再抵扣
  • 代驾公司增值税怎么交
  • 进口增值税 海关
  • 销售自建的不动产如何缴纳增值税
  • 旅行社确定收入毛利成本怎么确定?
  • 销售结算款扣款怎么记账?
  • 增值税一般项目是指什么
  • 收取赔偿金开具什么发票
  • 认定为虚开进项发票我的业务是真实的
  • 进项税额转出会计处理
  • win10 100g不够
  • 信息技术费用如何做分录
  • 非营利组织一般纳税人会计准则
  • won10字体变大
  • 代垫费用的进项税怎么算
  • 公司的净资产总值怎么算
  • 小规模纳税人税控设备可以抵扣吗设备
  • 企业汇算清缴怎么退税
  • php-cgi
  • 股权交易的重要性
  • 一般经营循环资金周转量为负数
  • 管家婆实物仓库怎么用
  • php ucwords() 函数将字符串中每个单词的首字符转换为大写(实现代码)
  • php忘记密码功能
  • 2023版最新最全React面试题
  • thinkphp route
  • 成本费用做账
  • 旅行社差额征税政策
  • 劳务派遣差额会计分录
  • 可供出售金融资产是流动资产吗
  • 生产部门使用的各种机器设备属于什么会计科目
  • 投资别人公司的注意事项
  • 跨年的发票可以退税吗
  • mongodb 入门
  • gin框架使用案例
  • 变电所用电
  • 所得税多交退回分录
  • 个体升一般纳税人的界限
  • 借款合同印花税优惠政策
  • sqlserver的isnull
  • 微信支付宝等第三方支付的优缺点
  • 服务业暂估成本怎样做账?
  • 工业企业新产品收入的调研报告
  • 红字冲销表示负数吗
  • 加油费不征税发票可以报销吗
  • 供应商质量索赔流程
  • 幼儿园固定资产一览表
  • 什么发票可以抵扣税
  • 根据索引名称查字段
  • foxmail反应慢的原因
  • Windows 7 和 Vista 下使用 Alipay 的解决方法总结
  • windows server 2003 r2 序列号
  • win7用户账户控制设置电脑重启后恢复
  • win7如何删除系统启动项
  • jsonarray fromobject
  • javascript相对路径
  • jquery mobile app案例
  • 监控网站是否可以删除
  • 深入浅出python中文第二版pdf
  • 批处理 !!
  • unity接入google内购
  • jquery 插件编写
  • 税务系统怎么修改办税人
  • 票折与票扣的区别在哪里
  • 2020税控盘升级后怎么使用
  • 纳税筹划是什么课
  • 新疆税务电子
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设