文章目录一、什么是JDBC二、JDBC工作原理三、使用JDBC连接MySQL数据库【?】1、安装对应数据驱动包2、将jar包导入项目中3、编写代码连接数据库【?】1?? 创建数据源2?? 和数据库建立网络连接3?? 构造SQL语句4?? 执行SQL语句5?? 断开连接释放资源4、测试观察5、代码优化1??灵活变通SQL2??防止SQL注入攻击6、SQL查找的写法7、SQL修改和删除的写法四、整体代码展示五、总结与提炼一、什么是JDBCJDBC即Java Database Connectivityjava数据库连接。是一种用于执行SQL语句的Java API它是Java中的数据库连接规范。这个API由java.sql.*,javax.sql.*包中的一些类和接口组成它为Java开发人员操作数据库提供了一个标准的API可以为多种关系数据库提供统一访问二、JDBC工作原理JDBC 为多种关系数据库提供了统一访问方式作为特定厂商数据库访问API的一种高级抽象它主要包含一些通用的接口类下面是我画的一张有关JDBC访问数据库层次结构的图可以看到我们程序员在开发JavaEE应用的时候通过调用Sun公司提供给我们的JDBC相关API就可以切访问数据库的JSBC驱动程序继而通过驱动来加载数据库JDBC优势Java语言访问数据库操作完全面向抽象接口编程开发数据库应用不用限定在特定数据库厂商的API程序的可移植性大大增强三、使用JDBC连接MySQL数据库【】1、安装对应数据驱动包那有同学就问了数据驱动包是什么?? 对于数据驱动包而言其实就是上面我所说到的各个【数据库厂商】所提供给我们的JDBC驱动程序因为只有数据库厂商那边提供给了我们加载数据库的驱动我们才能去获取到数据库中的数据表然后进行CRUD等操作这样说呢可能还不是很好理解我们可以通过画图来帮助理解知道了JDBC的工作原理后我们还要去了解什么去驱动包接下去就要去下载这个驱动包去哪里下呢当然是官网但是呢官网很麻烦你要一个个地去找不知道要下那个才好下面是MySQL的官网的驱动下载处很好找。但若是你用的是Oracle数据库的话就会很麻烦了因为它们这家公司很大产品也很多所以官网中会很很多东西你很难去找到自己想要的驱动程序难道这就没办法了吗要一个个找吗??当然有那就是我们心爱的【Maven】对于Maven而言学Java的同学一定不陌生它是一个 “中央仓库”Maven 作为 Java 项目管理工具它不仅可以用作包管理还有许多的插件可以支持整个项目的开发、打包、测试及部署等一系列行为简直是居家旅行、杀人灭口必备良药咳咳然后我们就可以去下载MySQL对应的驱动包了按照下图指示来即可点进去之后就可以选择对应的驱动包版本了但是这里在选择的时候要注意了需要和你MySQL安装的版本一致才可我的MySQL是5.7的所以这里大版本不能变要选择5.1开头的后面的小版本没关系当然如果你的MySQL是8.x版本的你就要选择8开头的驱动包了点进去之后我们看到有个jar点一下它你就可以拥有一个MySQL相关的驱动包了就和我们平常使用的.rar、.zip压缩包没什么区别就是Java的压缩包以.jar结尾下载好了之后就是这个样子的2、将jar包导入项目中现在我们有了这个jar后就要把它用起来那现在我们去新建一个项目然后把这个包导进来不过在此之前要新建一个名为lib的目录它是library库的缩写当然你也可以写其他的名称然后右键这个目录选择【添加为库…】此时这个MySQL的驱动库就导入到我们的项目中了3、编写代码连接数据库【】加载完MySQL的驱动包之后我们就可以使用一些API去操作数据库了准备好了吗发车了??1 创建数据源??首先第一点要连接数据库的话我们就要知道这个数据库在哪里这里我会介绍两种方式一个是通过DataSource数据源对象获取另一种则是通过DriverManager驱动管理类的静态方法获取不过重点在于第一种①DataSource数据源对象获取下面是创建数据源的相关代码我使用到了Java中的向上转型和向下转型不是很清楚的同学可以先去了解一下DataSource dataSource new MysqlDataSource();((MysqlDataSource)dataSource).setURL(“jdbc:mysql://127.0.0.1:3306/test?characterEncodingutf8useSSLfalse”);((MysqlDataSource)dataSource).setUser(“root”);((MysqlDataSource)dataSource).setPassword(“xxxxxxxxxxx”);也就是这一句我使用到了向上转型DataSource是Java中的一个接口MysqlDataSource则是它的实现类下面这种便是很典型的使用接口来实现向上转型DataSource dataSource new MysqlDataSource();然后下面的setURL()、setUser()、setPassWord()都是【MysqlDataSource】这个接口实现类中的一些方法但是由于向上转型后父类无法去调用子类独有的方法所以我们还要去进行一个向下转型通过去进行一个强制类型转换就可以做到此时我们便能调用到实现类中的方法了((MysqlDataSource)dataSource).setURL(…)((MysqlDataSource)dataSource).setUser(…)((MysqlDataSource)dataSource).setPassWord(…)?? 那有同学问为什么要这么麻烦呢转上又转下直接使用MysqlDataSource不就好了道理确实是这样如果我们直接将代码写成下面这样子那么就可以直接去调用这个类中的方法了无需再去做一个向下转型但是这却隐藏着巨大的隐患…MysqlDataSource dataSource1 new MysqlDataSource();可能没有真正做过开发的同学还体会不到这一点因为我们在设计一些接口、类的时候始终要遵循【高内聚 · 低耦合】的思想即类的内部各个方法之间要紧密关联但类与类之间不要产生太大的依赖光这么说可能说不太清楚有兴趣的同学可以先去了解一下高内聚 · 低耦合因为在上面我们使用的是【MysqlDataSource 】所以在程序的其他方法中我们可能也需要使用到这个类去做一个接受就是因为这种高内聚的原因导致了【MysqlDataSource 】被大量地进行扩散此危害性就在于后续我们的项目要更换数据库的就需要改动很多的代码加大了工作量void func1(MysqlDataSource dataSource1){}void func2(MysqlDataSource dataSource2){}然后呢我们再来说说为什么要去调用这些API首先的话是serURL()对于【URL】来说学习过HTTP协议的同学应该是非常熟悉对于浏览器发送的HTTP请求中第一行就是URL它叫做统一资源定位符也就是我们日常生活中所说的【网址】描述了互联网上唯一一个资源的位置我们可以来解读一下这个所传入的这个URL那对于下面的User和PassWord就很清楚了就是用户名和密码MySQL用户名固定就是【root】密码的话就是你安装MySQL的时候手动设置的密码。虽然很多数据库是根据用户名和密码来进行认证的但是有些数据库向SQLite就不是用的这个进行认证所以这就是为什么这些方法均在【MysqlDataSource 】里的原因了每个数据库都有它们独特的验证方式所以我们在使用不同数据库时加载不同的驱动包即可2 和数据库建立网络连接在上面呢我们只是进行了数据源的创建操作只是描述了服务器在哪并没有真正得进行访问那现在我们所要做的操作就是【连接】通过网络去进行一个通信然后我们就可以通过【DataSource】接口中一个方法叫做getConnection()这个方法去建立一个网络连接它会返回一个实例为【Connection】的对象不过从下图可以看到很多种类的Connection那我们选哪个呢这里要注意选择这个java.sql的这才是我们想要的ConnectionConnection connection dataSource.getConnection();要注意这里了连接Connection而不是链接Link对于连接而言并不复杂因为只有这么一句代码因为在网络中客户端和服务器之间要去建立一个连接就只是找个地方记录下而已并不需要非常繁琐的步骤而且还要注意的是这个getConnection()还需要去处理异常一般来说像我们在进行文件读取、数据库操作都是需要去捕获这个异常的这里我直接【throws】了你也可以【try…catch】如果异常还不是很了解的同学再去学习一下打个比方说就像民政局登记结婚一样只是找个地方登记一下我们结婚了也无需像婚礼那样大动干戈②DriverManager驱动管理类的静态方法获取讲了这么多别忘了我们只讲了一种数据库连接方式别忘了还有第二种那就是使用DriverManager但是我并不打算讲解这种方式因为它需要借助我们在JavaSE中所学习的【反射】但是对于反射来说其实是不属于常规的编程手段不在特殊的情况下还是不推荐使用的。你可以在看了下面这两种连接方式的区别后再来回顾// 加载JDBC驱动程序Class.forName(“com.mysql.jdbc.Driver”);// 创建数据库连接Connection connection DriverManager.getConnection(url);区别DriverManager类来获取的Connection连接是无法重复利用的每次使用完以后释放资源时通过connection.close()都是关闭物理连接。DataSource提供连接池的支持。连接池在初始化时将内置了【数据库连接池】这些连接是可以复用的每次使用完数据库连接释放资源调用connection.close()都是将Conncetion连接对象回收?? 可能有同学对这个【数据库连接池】不太理解我们这里来讲一讲doge在Java中呢我们学习过很多的池比方说String字符串常量池、进程池、线程池、内存池它们都是池那谈到池这个东西我们就想到了【池塘】那假设呢你现在是个妹子长得好看又有才华所以追求者就与很多但是呢同一时间只能谈一个对象但是你又不想拒绝其他的追求者因为如果当前这个对象谈到后面谈不来的话就需要再换一个此时的话就会有很多的成本因为需要重新培养感情那于是你就想了一个很不错的办法来提高效率那就是【养鱼??】怎么养鱼呢也就是在和A谈对象的同时和B搞暧昧同时培养感情基础一旦你和A分手了就可以立马和B在一起此时大大提高了效率那么这个B就被亲切地称之为【备胎】但是你的备胎可能还不只B这一个可能还有CDEFGHI…此时它们就构成了一个“备胎池”若是B不合适了还可以换其他人上位而且呢这个时候A也还在池子里若是你和其他人都不和的时候又想到A了此时你就可以再和A在一起当然上面只是举一个小小的案例现实生活中我们不提倡这么去做~ 但是在计算机里这种做法还是很常见的可以了解一下3 构造SQL语句接下去呢我们就要去构造SQL语句了首先定义一个字符串表示一条插入语句String sql “insert into student values (1, ‘zhansan’)”;但是呢有这条语句还不够在JDBC中我们还需要搭配一个对象去描述这里的sql情况PreparedStatement statement connection.prepareStatement(sql);?? 这里主要讲一下这个PreparedStatement可能有很多同学看懵了。首先对于【startment】对象来说是将SQL语句发送到数据库中。JDBC API中主要提供了三种Statement对象StatementPreparedStatementCallableStartment不过我们在工作中用得最多的还是PreparedStatement字面意思的话就是【预处理语句】对于PreparedStatement来说它其实在底层帮我们做了许多事情不过这里不做详解有兴趣的同学可以去了解一下Java数据库JDBC——prepareStatement的用法和解释4 执行SQL语句在构造完SQL语句后我们就可以去通过这个statement对象去执行SQL语句了只需要调用这个类中的executeUpdate()即可如果你要执行的SQL语句是【增】、【删】、【改】操作的话那么你的SQL执行语句就写下面这一条就可以了statement.executeUpdate();但若是你执行的是【查】操作的话结果就不是这样了而是要写成下面这句statement.executeQuery();5 断开连接释放资源当然在执行完了之后还要再断开连接释放掉必要的资源可以看到我们上面所创建出来的两个对象connection和statement但是你自己观察就可以发现我在关闭资源的时候是反着来的这就是因为资源释放的顺序和创建的顺序是相反的statement.close();connection.close();如果读者学习过C的话就会很好理解了因为C类和对象中存在【析构函数】对象销毁的时候是存在顺序的但是因为Java中有GC垃圾自动回收机制所以我们一般不需要自己去释放申请的空间编译器会去做这件事的这里我还是来讲一下这个构造析构的顺序帮助读者来进行理解不知道你去过东北没有反正那边是冬天是挺冷的零下三四十度不过北方的房子还是很有意思的一般我们家里都是只有一个院子的但是在北方一般都有两个院子而且有两个门你跨入第一个门相当于进入外院再跨一个门才算是进入了内院主院那此时也就是意味着你要进入内院的话就需要先通过【大门】然后再通过【二门】但若是你要出来的话肯定就得先通过【二门】才能到达【大门】假设你不会飞??那通过上面这样已说明相信你对构造、析构的这么一个过程很熟悉了后构造的对象就需要先析构才可以4、测试观察写好了JDBC连接MySQL数据库的代码逻辑接下去我们就来测试一下是否真的可以去操作数据库首先可以看到的是当前这个数据表studennt中是不存在任何记录的然后我们到IDEA中去执行一下这段代码的话就可以看到ret的结果为1表名SQL语句执行成功然后我们再到数据库中去查看的时候就可以发现有一条记录被插入进来了这也就实现了用JDBC去操作数据表的功能?? 如果你是第一次看到的话一定会觉得很神奇就像我在第一次看到后端代码可以与前端进行交互的时候我也很吃惊现在又看到可以通过后端的代码来操作数据库又让我觉得耳目一新5、代码优化上面只是做了基本的测试代表我们的代码可以去连接到数据库但是这份代码还不够【完善】我们再来完善一下~1灵活变通SQL这是我们写的SQL语句但你是否觉得这样去写太死了通常我们在操作数据库的时候都会写很多SQL语句是非常灵活的但是就下面这样的话确实是不太好String sql “insert into student values (1, ‘zhansan’)”;所以我们可以将代码改为下面这样记录中的【学号】和【姓名】字段我们可以通过自己输入来进行控制// 3.输入学号和姓名System.out.println(“请输入学号”);Scanner sc1 new Scanner(System.in);int id sc1.nextInt();System.out.println(“请输入姓名”);Scanner sc2 new Scanner(System.in);String name sc2.next();// 4.构造一个 SQL 语句来完成插入操作//String sql “insert into student values (1, ‘zhansan’)”;String sql “insert into student values (” id “, ” name “)”;此时我们通过控制台去进行输入就后构造出SQL语句然后执行就可以发现也是可以插入一条记录的2防止SQL注入攻击但是对于上面这样的SQL语句构造你可以看出来是比较丑的不方便阅读与理解不仅如此它还容易引起【SQL注入攻击】可能有的同学不太清楚这个【SQL注入攻击】它是黑客入侵服务器的一种形式黑客可以通过代码直接拼接构造sql语句导致sql语句结构可被恶意篡改有兴趣的同学可以去了解一下 链接对于上面这种危害我们进行预防最靠谱的方案就是使用PreparedStatement中占位符替换的方式来实现SQL的构造~我们可以把SQL语句构造成下面这样两个【】就相当于是占位符String sql “insert into student values (?, ?)”; //通过占位符进行替换还记得我们上面使用到的那个statement对象吗它可以用来描述SQL的情况我们可以通过里面的【setInt()】和【setString()】方法来设置记录中的两个字段从而将这个SQL语句构造完整// jdbc中还需要搭配一个特定的对象来搭配描述这里的sql情况PreparedStatement statement connection.prepareStatement(sql);statement.setInt(1, id);statement.setString(2, name);然后再去运行的话就可以看到也是可以把记录插入到数据表中的?? 对于上面这种形式就是较为安全的SQL语句写法代码会在文末给出可供读者参考6、SQL查找的写法上面的话就只是SQL的插入学习过CRUD的同学们一定还会其他操作对于【删除】、【修改】的话和插入是一模一样的只需要修改一下SQL语句的构造即可。??但是对于【查找】操作就不一样了和上面的这些操作相比多了一个遍历结果集首先的话我们要去修改一下SQL语句改为查询的语句String sql “select * from student”;然后在执行SQL语句的时候就不能写成executeUpdate()了而是要写成executeQuery()而且返回的结果也不一样若是【增】、【删】、【改】的话返回的就只是一个【int】类型的值表示SQL语句是否执行成功但是对于【查】的话就不一样了因为一个数据表中的记录不止一条所以它查找就会返回一个结果集我们要使用[ResultSet]来进行接受ResultSet ret statement.executeQuery();那既然这是一个集合的话我们要看到里面的内容就要去进行一个遍历的操作此时和【迭代器】的遍历很相似通过ret.next()去进行判断是否还有下一条记录需要遍历即可内部去获取到记录中的相关字段然后显示打印出来即可while(ret.next()){int id ret.getInt(“id”);String name ret.getString(“name”);System.out.println(id id ; name name);}执行程序就可以看到遍历出了这张表中的所有内容7、SQL修改和删除的写法本小节是后面补充的主要是为了让读者更加明白JDBC中如何构造SQL语句并连接数据库以下是具体的Update修改语句同样我们使用?来作为占位符String sql “update student set name ? where id ?”;然后在描述SQL的时候将参数值给设置上去然后才能变成一个完整的SQL然后来看一下执行的结果看到返回值是1就可以知道修改成功了接下去我们来看看删除语句该如何去写同样只需要去修改一下SQL语句即可以及在描述SQL的时候也要去做一个改进String sql “delete from student where id ?”;然后再去执行这个SQL的时候就可以发现当前数据库中的唯一记录也被删除了四、整体代码展示上面就是通过JDBC连接数据库的这么一套流程你学会了吗??JDBC往数据表插入记录public class JDBCInsertDemo { public static void main(String[] args) throws SQLException { /** * 使用 JDBC 往数据库中插入一个记录 * 需要提前准备好数据库(java106) 和 数据表(student) */ // 1.创建数据源描述了数据库服务器在哪 DataSource dataSource new MysqlDataSource(); ((MysqlDataSource)dataSource).setURL(jdbc:mysql://127.0.0.1:3306/test?characterEncodingutf8useSSLfalse); ((MysqlDataSource)dataSource).setUser(root); ((MysqlDataSource)dataSource).setPassword(panjialie1218); // 2.和数据库建立网络连接 (写JDBC实际上是实现一个MySQL客户端通过网络和服务器进行通讯) Connection connection dataSource.getConnection(); // 3.输入学号和姓名 System.out.println(请输入学号); Scanner sc1 new Scanner(System.in); int id sc1.nextInt(); System.out.println(请输入姓名); Scanner sc2 new Scanner(System.in); String name sc2.next(); // 4.构造一个 SQL 语句来完成插入操作 //String sql insert into student values (1, zhansan); -- 太死板 //String sql insert into student values ( id , name ); -- 会SQL注入攻击 String sql insert into student values (?, ?); //通过占位符进行替换 // jdbc中还需要搭配一个特定的对象来搭配描述这里的sql情况 PreparedStatement statement connection.prepareStatement(sql); statement.setInt(1, id); statement.setString(2, name); // 5.执行 SQL 语句 (控制客户端给服务器发送请求) int ret statement.executeUpdate(); System.out.println(ret ret); // 6.断开和数据库的连接并且释放掉必要的资源 statement.close(); connection.close(); } }JDBC查询数据表记录public class JDBCSelectDemo { public static void main(String[] args) throws SQLException { /** * 使用 JDBC 往数据库中插入一个记录 * 需要提前准备好数据库(java106) 和 数据表(student) */ // 1.创建数据源描述了数据库服务器在哪 DataSource dataSource new MysqlDataSource(); ((MysqlDataSource)dataSource).setURL(jdbc:mysql://127.0.0.1:3306/test?characterEncodingutf8useSSLfalse); ((MysqlDataSource)dataSource).setUser(root); ((MysqlDataSource)dataSource).setPassword(panjialie1218); // 2.和数据库建立网络连接 (写JDBC实际上是实现一个MySQL客户端通过网络和服务器进行通讯) Connection connection dataSource.getConnection(); // 3.构造一个 SQL 语句来完成插入操作 String sql select * from student; // jdbc中还需要搭配一个特定的对象来搭配描述这里的sql情况 PreparedStatement statement connection.prepareStatement(sql); // 5.执行 SQL 语句 (控制客户端给服务器发送请求) ResultSet ret statement.executeQuery(); while(ret.next()) { int id ret.getInt(id); String name ret.getString(name); System.out.println(id id ; name name); } // 6.断开和数据库的连接并且释放掉必要的资源 statement.close(); connection.close(); } }对于【修改】和【删除】这里只给出改动的地方其余的参照【插入】JDBC修改数据表记录// 3.输入学号和姓名 System.out.println(请输入你要修改的学号); Scanner sc1 new Scanner(System.in); int id sc1.nextInt(); System.out.println(请输入你要修改的姓名); Scanner sc2 new Scanner(System.in); String name sc2.next(); // 4.构造SQL语句, 来完成更新操作 String sql update student set name ? where id ?; // jdbc中还需要搭配一个特定的对象, 来搭配描述这里的sql情况 PreparedStatement statement connection.prepareStatement(sql); statement.setString(1, name); statement.setInt(2, id);JDBC删除数据表记录// 3.输入学号和姓名 System.out.println(请输入你要删除学生的学号); Scanner sc new Scanner(System.in); int id sc.nextInt(); // 4.构造SQL语句, 来完成更新操作 String sql delete from student where id ?; // jdbc中还需要搭配一个特定的对象, 来搭配描述这里的sql情况 PreparedStatement statement connection.prepareStatement(sql); statement.setInt(1, id);五、总结与提炼最后来总结一下本文所学习的内容??在本文中我们首先了解了JDBC的概念以及其相关工作原理然后的话就通过调用这些JDBC相关的API去加载MySQL数据库的驱动一步步地去创建数据源、建立连接、构造与执行SQL语句最后释放连接完成了通过后端代码去操作数据库成功往数据表中插入了一条记录接下去呢我们又对代码去进行了一个优化既提高了代码的灵活性还可以防止SQL注入攻击加固了代码的安全性。然后又完成了查询数据表的相关记录的操作需要涉及对集合的遍历?? 可能本文的读者不会很多但如果你读到这里的话那我要和你说一个事实因为现在几乎都不用JDBC了市面上有一个很成熟的框架叫做【MyBatis】它是款优秀的持久层框架它持定义 SQL、存储过程以及级映射但是其底层的实现还是基于JDBC的。框架都是层出不穷的唯有内部核心是永恒不变的学到底层才是关键??以上就是本文要介绍的所有内容感谢您的阅读??
MySQL JDBC连接数据库详细教程【全程干货】
文章目录一、什么是JDBC二、JDBC工作原理三、使用JDBC连接MySQL数据库【?】1、安装对应数据驱动包2、将jar包导入项目中3、编写代码连接数据库【?】1?? 创建数据源2?? 和数据库建立网络连接3?? 构造SQL语句4?? 执行SQL语句5?? 断开连接释放资源4、测试观察5、代码优化1??灵活变通SQL2??防止SQL注入攻击6、SQL查找的写法7、SQL修改和删除的写法四、整体代码展示五、总结与提炼一、什么是JDBCJDBC即Java Database Connectivityjava数据库连接。是一种用于执行SQL语句的Java API它是Java中的数据库连接规范。这个API由java.sql.*,javax.sql.*包中的一些类和接口组成它为Java开发人员操作数据库提供了一个标准的API可以为多种关系数据库提供统一访问二、JDBC工作原理JDBC 为多种关系数据库提供了统一访问方式作为特定厂商数据库访问API的一种高级抽象它主要包含一些通用的接口类下面是我画的一张有关JDBC访问数据库层次结构的图可以看到我们程序员在开发JavaEE应用的时候通过调用Sun公司提供给我们的JDBC相关API就可以切访问数据库的JSBC驱动程序继而通过驱动来加载数据库JDBC优势Java语言访问数据库操作完全面向抽象接口编程开发数据库应用不用限定在特定数据库厂商的API程序的可移植性大大增强三、使用JDBC连接MySQL数据库【】1、安装对应数据驱动包那有同学就问了数据驱动包是什么?? 对于数据驱动包而言其实就是上面我所说到的各个【数据库厂商】所提供给我们的JDBC驱动程序因为只有数据库厂商那边提供给了我们加载数据库的驱动我们才能去获取到数据库中的数据表然后进行CRUD等操作这样说呢可能还不是很好理解我们可以通过画图来帮助理解知道了JDBC的工作原理后我们还要去了解什么去驱动包接下去就要去下载这个驱动包去哪里下呢当然是官网但是呢官网很麻烦你要一个个地去找不知道要下那个才好下面是MySQL的官网的驱动下载处很好找。但若是你用的是Oracle数据库的话就会很麻烦了因为它们这家公司很大产品也很多所以官网中会很很多东西你很难去找到自己想要的驱动程序难道这就没办法了吗要一个个找吗??当然有那就是我们心爱的【Maven】对于Maven而言学Java的同学一定不陌生它是一个 “中央仓库”Maven 作为 Java 项目管理工具它不仅可以用作包管理还有许多的插件可以支持整个项目的开发、打包、测试及部署等一系列行为简直是居家旅行、杀人灭口必备良药咳咳然后我们就可以去下载MySQL对应的驱动包了按照下图指示来即可点进去之后就可以选择对应的驱动包版本了但是这里在选择的时候要注意了需要和你MySQL安装的版本一致才可我的MySQL是5.7的所以这里大版本不能变要选择5.1开头的后面的小版本没关系当然如果你的MySQL是8.x版本的你就要选择8开头的驱动包了点进去之后我们看到有个jar点一下它你就可以拥有一个MySQL相关的驱动包了就和我们平常使用的.rar、.zip压缩包没什么区别就是Java的压缩包以.jar结尾下载好了之后就是这个样子的2、将jar包导入项目中现在我们有了这个jar后就要把它用起来那现在我们去新建一个项目然后把这个包导进来不过在此之前要新建一个名为lib的目录它是library库的缩写当然你也可以写其他的名称然后右键这个目录选择【添加为库…】此时这个MySQL的驱动库就导入到我们的项目中了3、编写代码连接数据库【】加载完MySQL的驱动包之后我们就可以使用一些API去操作数据库了准备好了吗发车了??1 创建数据源??首先第一点要连接数据库的话我们就要知道这个数据库在哪里这里我会介绍两种方式一个是通过DataSource数据源对象获取另一种则是通过DriverManager驱动管理类的静态方法获取不过重点在于第一种①DataSource数据源对象获取下面是创建数据源的相关代码我使用到了Java中的向上转型和向下转型不是很清楚的同学可以先去了解一下DataSource dataSource new MysqlDataSource();((MysqlDataSource)dataSource).setURL(“jdbc:mysql://127.0.0.1:3306/test?characterEncodingutf8useSSLfalse”);((MysqlDataSource)dataSource).setUser(“root”);((MysqlDataSource)dataSource).setPassword(“xxxxxxxxxxx”);也就是这一句我使用到了向上转型DataSource是Java中的一个接口MysqlDataSource则是它的实现类下面这种便是很典型的使用接口来实现向上转型DataSource dataSource new MysqlDataSource();然后下面的setURL()、setUser()、setPassWord()都是【MysqlDataSource】这个接口实现类中的一些方法但是由于向上转型后父类无法去调用子类独有的方法所以我们还要去进行一个向下转型通过去进行一个强制类型转换就可以做到此时我们便能调用到实现类中的方法了((MysqlDataSource)dataSource).setURL(…)((MysqlDataSource)dataSource).setUser(…)((MysqlDataSource)dataSource).setPassWord(…)?? 那有同学问为什么要这么麻烦呢转上又转下直接使用MysqlDataSource不就好了道理确实是这样如果我们直接将代码写成下面这样子那么就可以直接去调用这个类中的方法了无需再去做一个向下转型但是这却隐藏着巨大的隐患…MysqlDataSource dataSource1 new MysqlDataSource();可能没有真正做过开发的同学还体会不到这一点因为我们在设计一些接口、类的时候始终要遵循【高内聚 · 低耦合】的思想即类的内部各个方法之间要紧密关联但类与类之间不要产生太大的依赖光这么说可能说不太清楚有兴趣的同学可以先去了解一下高内聚 · 低耦合因为在上面我们使用的是【MysqlDataSource 】所以在程序的其他方法中我们可能也需要使用到这个类去做一个接受就是因为这种高内聚的原因导致了【MysqlDataSource 】被大量地进行扩散此危害性就在于后续我们的项目要更换数据库的就需要改动很多的代码加大了工作量void func1(MysqlDataSource dataSource1){}void func2(MysqlDataSource dataSource2){}然后呢我们再来说说为什么要去调用这些API首先的话是serURL()对于【URL】来说学习过HTTP协议的同学应该是非常熟悉对于浏览器发送的HTTP请求中第一行就是URL它叫做统一资源定位符也就是我们日常生活中所说的【网址】描述了互联网上唯一一个资源的位置我们可以来解读一下这个所传入的这个URL那对于下面的User和PassWord就很清楚了就是用户名和密码MySQL用户名固定就是【root】密码的话就是你安装MySQL的时候手动设置的密码。虽然很多数据库是根据用户名和密码来进行认证的但是有些数据库向SQLite就不是用的这个进行认证所以这就是为什么这些方法均在【MysqlDataSource 】里的原因了每个数据库都有它们独特的验证方式所以我们在使用不同数据库时加载不同的驱动包即可2 和数据库建立网络连接在上面呢我们只是进行了数据源的创建操作只是描述了服务器在哪并没有真正得进行访问那现在我们所要做的操作就是【连接】通过网络去进行一个通信然后我们就可以通过【DataSource】接口中一个方法叫做getConnection()这个方法去建立一个网络连接它会返回一个实例为【Connection】的对象不过从下图可以看到很多种类的Connection那我们选哪个呢这里要注意选择这个java.sql的这才是我们想要的ConnectionConnection connection dataSource.getConnection();要注意这里了连接Connection而不是链接Link对于连接而言并不复杂因为只有这么一句代码因为在网络中客户端和服务器之间要去建立一个连接就只是找个地方记录下而已并不需要非常繁琐的步骤而且还要注意的是这个getConnection()还需要去处理异常一般来说像我们在进行文件读取、数据库操作都是需要去捕获这个异常的这里我直接【throws】了你也可以【try…catch】如果异常还不是很了解的同学再去学习一下打个比方说就像民政局登记结婚一样只是找个地方登记一下我们结婚了也无需像婚礼那样大动干戈②DriverManager驱动管理类的静态方法获取讲了这么多别忘了我们只讲了一种数据库连接方式别忘了还有第二种那就是使用DriverManager但是我并不打算讲解这种方式因为它需要借助我们在JavaSE中所学习的【反射】但是对于反射来说其实是不属于常规的编程手段不在特殊的情况下还是不推荐使用的。你可以在看了下面这两种连接方式的区别后再来回顾// 加载JDBC驱动程序Class.forName(“com.mysql.jdbc.Driver”);// 创建数据库连接Connection connection DriverManager.getConnection(url);区别DriverManager类来获取的Connection连接是无法重复利用的每次使用完以后释放资源时通过connection.close()都是关闭物理连接。DataSource提供连接池的支持。连接池在初始化时将内置了【数据库连接池】这些连接是可以复用的每次使用完数据库连接释放资源调用connection.close()都是将Conncetion连接对象回收?? 可能有同学对这个【数据库连接池】不太理解我们这里来讲一讲doge在Java中呢我们学习过很多的池比方说String字符串常量池、进程池、线程池、内存池它们都是池那谈到池这个东西我们就想到了【池塘】那假设呢你现在是个妹子长得好看又有才华所以追求者就与很多但是呢同一时间只能谈一个对象但是你又不想拒绝其他的追求者因为如果当前这个对象谈到后面谈不来的话就需要再换一个此时的话就会有很多的成本因为需要重新培养感情那于是你就想了一个很不错的办法来提高效率那就是【养鱼??】怎么养鱼呢也就是在和A谈对象的同时和B搞暧昧同时培养感情基础一旦你和A分手了就可以立马和B在一起此时大大提高了效率那么这个B就被亲切地称之为【备胎】但是你的备胎可能还不只B这一个可能还有CDEFGHI…此时它们就构成了一个“备胎池”若是B不合适了还可以换其他人上位而且呢这个时候A也还在池子里若是你和其他人都不和的时候又想到A了此时你就可以再和A在一起当然上面只是举一个小小的案例现实生活中我们不提倡这么去做~ 但是在计算机里这种做法还是很常见的可以了解一下3 构造SQL语句接下去呢我们就要去构造SQL语句了首先定义一个字符串表示一条插入语句String sql “insert into student values (1, ‘zhansan’)”;但是呢有这条语句还不够在JDBC中我们还需要搭配一个对象去描述这里的sql情况PreparedStatement statement connection.prepareStatement(sql);?? 这里主要讲一下这个PreparedStatement可能有很多同学看懵了。首先对于【startment】对象来说是将SQL语句发送到数据库中。JDBC API中主要提供了三种Statement对象StatementPreparedStatementCallableStartment不过我们在工作中用得最多的还是PreparedStatement字面意思的话就是【预处理语句】对于PreparedStatement来说它其实在底层帮我们做了许多事情不过这里不做详解有兴趣的同学可以去了解一下Java数据库JDBC——prepareStatement的用法和解释4 执行SQL语句在构造完SQL语句后我们就可以去通过这个statement对象去执行SQL语句了只需要调用这个类中的executeUpdate()即可如果你要执行的SQL语句是【增】、【删】、【改】操作的话那么你的SQL执行语句就写下面这一条就可以了statement.executeUpdate();但若是你执行的是【查】操作的话结果就不是这样了而是要写成下面这句statement.executeQuery();5 断开连接释放资源当然在执行完了之后还要再断开连接释放掉必要的资源可以看到我们上面所创建出来的两个对象connection和statement但是你自己观察就可以发现我在关闭资源的时候是反着来的这就是因为资源释放的顺序和创建的顺序是相反的statement.close();connection.close();如果读者学习过C的话就会很好理解了因为C类和对象中存在【析构函数】对象销毁的时候是存在顺序的但是因为Java中有GC垃圾自动回收机制所以我们一般不需要自己去释放申请的空间编译器会去做这件事的这里我还是来讲一下这个构造析构的顺序帮助读者来进行理解不知道你去过东北没有反正那边是冬天是挺冷的零下三四十度不过北方的房子还是很有意思的一般我们家里都是只有一个院子的但是在北方一般都有两个院子而且有两个门你跨入第一个门相当于进入外院再跨一个门才算是进入了内院主院那此时也就是意味着你要进入内院的话就需要先通过【大门】然后再通过【二门】但若是你要出来的话肯定就得先通过【二门】才能到达【大门】假设你不会飞??那通过上面这样已说明相信你对构造、析构的这么一个过程很熟悉了后构造的对象就需要先析构才可以4、测试观察写好了JDBC连接MySQL数据库的代码逻辑接下去我们就来测试一下是否真的可以去操作数据库首先可以看到的是当前这个数据表studennt中是不存在任何记录的然后我们到IDEA中去执行一下这段代码的话就可以看到ret的结果为1表名SQL语句执行成功然后我们再到数据库中去查看的时候就可以发现有一条记录被插入进来了这也就实现了用JDBC去操作数据表的功能?? 如果你是第一次看到的话一定会觉得很神奇就像我在第一次看到后端代码可以与前端进行交互的时候我也很吃惊现在又看到可以通过后端的代码来操作数据库又让我觉得耳目一新5、代码优化上面只是做了基本的测试代表我们的代码可以去连接到数据库但是这份代码还不够【完善】我们再来完善一下~1灵活变通SQL这是我们写的SQL语句但你是否觉得这样去写太死了通常我们在操作数据库的时候都会写很多SQL语句是非常灵活的但是就下面这样的话确实是不太好String sql “insert into student values (1, ‘zhansan’)”;所以我们可以将代码改为下面这样记录中的【学号】和【姓名】字段我们可以通过自己输入来进行控制// 3.输入学号和姓名System.out.println(“请输入学号”);Scanner sc1 new Scanner(System.in);int id sc1.nextInt();System.out.println(“请输入姓名”);Scanner sc2 new Scanner(System.in);String name sc2.next();// 4.构造一个 SQL 语句来完成插入操作//String sql “insert into student values (1, ‘zhansan’)”;String sql “insert into student values (” id “, ” name “)”;此时我们通过控制台去进行输入就后构造出SQL语句然后执行就可以发现也是可以插入一条记录的2防止SQL注入攻击但是对于上面这样的SQL语句构造你可以看出来是比较丑的不方便阅读与理解不仅如此它还容易引起【SQL注入攻击】可能有的同学不太清楚这个【SQL注入攻击】它是黑客入侵服务器的一种形式黑客可以通过代码直接拼接构造sql语句导致sql语句结构可被恶意篡改有兴趣的同学可以去了解一下 链接对于上面这种危害我们进行预防最靠谱的方案就是使用PreparedStatement中占位符替换的方式来实现SQL的构造~我们可以把SQL语句构造成下面这样两个【】就相当于是占位符String sql “insert into student values (?, ?)”; //通过占位符进行替换还记得我们上面使用到的那个statement对象吗它可以用来描述SQL的情况我们可以通过里面的【setInt()】和【setString()】方法来设置记录中的两个字段从而将这个SQL语句构造完整// jdbc中还需要搭配一个特定的对象来搭配描述这里的sql情况PreparedStatement statement connection.prepareStatement(sql);statement.setInt(1, id);statement.setString(2, name);然后再去运行的话就可以看到也是可以把记录插入到数据表中的?? 对于上面这种形式就是较为安全的SQL语句写法代码会在文末给出可供读者参考6、SQL查找的写法上面的话就只是SQL的插入学习过CRUD的同学们一定还会其他操作对于【删除】、【修改】的话和插入是一模一样的只需要修改一下SQL语句的构造即可。??但是对于【查找】操作就不一样了和上面的这些操作相比多了一个遍历结果集首先的话我们要去修改一下SQL语句改为查询的语句String sql “select * from student”;然后在执行SQL语句的时候就不能写成executeUpdate()了而是要写成executeQuery()而且返回的结果也不一样若是【增】、【删】、【改】的话返回的就只是一个【int】类型的值表示SQL语句是否执行成功但是对于【查】的话就不一样了因为一个数据表中的记录不止一条所以它查找就会返回一个结果集我们要使用[ResultSet]来进行接受ResultSet ret statement.executeQuery();那既然这是一个集合的话我们要看到里面的内容就要去进行一个遍历的操作此时和【迭代器】的遍历很相似通过ret.next()去进行判断是否还有下一条记录需要遍历即可内部去获取到记录中的相关字段然后显示打印出来即可while(ret.next()){int id ret.getInt(“id”);String name ret.getString(“name”);System.out.println(id id ; name name);}执行程序就可以看到遍历出了这张表中的所有内容7、SQL修改和删除的写法本小节是后面补充的主要是为了让读者更加明白JDBC中如何构造SQL语句并连接数据库以下是具体的Update修改语句同样我们使用?来作为占位符String sql “update student set name ? where id ?”;然后在描述SQL的时候将参数值给设置上去然后才能变成一个完整的SQL然后来看一下执行的结果看到返回值是1就可以知道修改成功了接下去我们来看看删除语句该如何去写同样只需要去修改一下SQL语句即可以及在描述SQL的时候也要去做一个改进String sql “delete from student where id ?”;然后再去执行这个SQL的时候就可以发现当前数据库中的唯一记录也被删除了四、整体代码展示上面就是通过JDBC连接数据库的这么一套流程你学会了吗??JDBC往数据表插入记录public class JDBCInsertDemo { public static void main(String[] args) throws SQLException { /** * 使用 JDBC 往数据库中插入一个记录 * 需要提前准备好数据库(java106) 和 数据表(student) */ // 1.创建数据源描述了数据库服务器在哪 DataSource dataSource new MysqlDataSource(); ((MysqlDataSource)dataSource).setURL(jdbc:mysql://127.0.0.1:3306/test?characterEncodingutf8useSSLfalse); ((MysqlDataSource)dataSource).setUser(root); ((MysqlDataSource)dataSource).setPassword(panjialie1218); // 2.和数据库建立网络连接 (写JDBC实际上是实现一个MySQL客户端通过网络和服务器进行通讯) Connection connection dataSource.getConnection(); // 3.输入学号和姓名 System.out.println(请输入学号); Scanner sc1 new Scanner(System.in); int id sc1.nextInt(); System.out.println(请输入姓名); Scanner sc2 new Scanner(System.in); String name sc2.next(); // 4.构造一个 SQL 语句来完成插入操作 //String sql insert into student values (1, zhansan); -- 太死板 //String sql insert into student values ( id , name ); -- 会SQL注入攻击 String sql insert into student values (?, ?); //通过占位符进行替换 // jdbc中还需要搭配一个特定的对象来搭配描述这里的sql情况 PreparedStatement statement connection.prepareStatement(sql); statement.setInt(1, id); statement.setString(2, name); // 5.执行 SQL 语句 (控制客户端给服务器发送请求) int ret statement.executeUpdate(); System.out.println(ret ret); // 6.断开和数据库的连接并且释放掉必要的资源 statement.close(); connection.close(); } }JDBC查询数据表记录public class JDBCSelectDemo { public static void main(String[] args) throws SQLException { /** * 使用 JDBC 往数据库中插入一个记录 * 需要提前准备好数据库(java106) 和 数据表(student) */ // 1.创建数据源描述了数据库服务器在哪 DataSource dataSource new MysqlDataSource(); ((MysqlDataSource)dataSource).setURL(jdbc:mysql://127.0.0.1:3306/test?characterEncodingutf8useSSLfalse); ((MysqlDataSource)dataSource).setUser(root); ((MysqlDataSource)dataSource).setPassword(panjialie1218); // 2.和数据库建立网络连接 (写JDBC实际上是实现一个MySQL客户端通过网络和服务器进行通讯) Connection connection dataSource.getConnection(); // 3.构造一个 SQL 语句来完成插入操作 String sql select * from student; // jdbc中还需要搭配一个特定的对象来搭配描述这里的sql情况 PreparedStatement statement connection.prepareStatement(sql); // 5.执行 SQL 语句 (控制客户端给服务器发送请求) ResultSet ret statement.executeQuery(); while(ret.next()) { int id ret.getInt(id); String name ret.getString(name); System.out.println(id id ; name name); } // 6.断开和数据库的连接并且释放掉必要的资源 statement.close(); connection.close(); } }对于【修改】和【删除】这里只给出改动的地方其余的参照【插入】JDBC修改数据表记录// 3.输入学号和姓名 System.out.println(请输入你要修改的学号); Scanner sc1 new Scanner(System.in); int id sc1.nextInt(); System.out.println(请输入你要修改的姓名); Scanner sc2 new Scanner(System.in); String name sc2.next(); // 4.构造SQL语句, 来完成更新操作 String sql update student set name ? where id ?; // jdbc中还需要搭配一个特定的对象, 来搭配描述这里的sql情况 PreparedStatement statement connection.prepareStatement(sql); statement.setString(1, name); statement.setInt(2, id);JDBC删除数据表记录// 3.输入学号和姓名 System.out.println(请输入你要删除学生的学号); Scanner sc new Scanner(System.in); int id sc.nextInt(); // 4.构造SQL语句, 来完成更新操作 String sql delete from student where id ?; // jdbc中还需要搭配一个特定的对象, 来搭配描述这里的sql情况 PreparedStatement statement connection.prepareStatement(sql); statement.setInt(1, id);五、总结与提炼最后来总结一下本文所学习的内容??在本文中我们首先了解了JDBC的概念以及其相关工作原理然后的话就通过调用这些JDBC相关的API去加载MySQL数据库的驱动一步步地去创建数据源、建立连接、构造与执行SQL语句最后释放连接完成了通过后端代码去操作数据库成功往数据表中插入了一条记录接下去呢我们又对代码去进行了一个优化既提高了代码的灵活性还可以防止SQL注入攻击加固了代码的安全性。然后又完成了查询数据表的相关记录的操作需要涉及对集合的遍历?? 可能本文的读者不会很多但如果你读到这里的话那我要和你说一个事实因为现在几乎都不用JDBC了市面上有一个很成熟的框架叫做【MyBatis】它是款优秀的持久层框架它持定义 SQL、存储过程以及级映射但是其底层的实现还是基于JDBC的。框架都是层出不穷的唯有内部核心是永恒不变的学到底层才是关键??以上就是本文要介绍的所有内容感谢您的阅读??