【JDBC】学习路径2-编写第一个JDBC程序
第一章:导入jar包
在未安装MySQL数据库的请务必安装,安装教程:【MySQL】从入门到掌握2-下载安装
connector/J下载地址:https://dev.mysql.com/downloads/connector/j/

选择对应平台下载即可。
Mac端请直接选择Platform Independent。
意思是“平台无关”,全平台通用。
下载完后解压包如下。

在IDEA中,选择项目结构,点击Libraries导入刚才下载的文件。


然后就可以了。
第二章:注册连接数据库
1-创建(测试用)数据库
连接数据库之前,先创建一个数据库。
打开控制台(终端),mysql -uroot -p
进入数据库后创建数据库:create database jdbc_01;
创建一张表格,一会用做测试:create table user(id int not null auto_increment,username varchar(45),password varchar(45),primary key(id));

插入几条数据:insert into user(username,password) values('remoo1','1234');
insert into user(username,password) values('remoo2','121234');
insert into user(username,password) values('BruceLiu','882200');
insert into user(username,password) values('Mariana','122344');
2-注册连接数据库
回到IDEA,
键入代码:
import java.sql.*;
public class demo01 {
public static void main(String[] args) {
try {
//注册驱动,使用该驱动连接数据库
Class.forName("com.mysql.jdbc.Driver");
//输入我们刚才创建的数据库名称
//String url = "jdbc:mysql://localhost:3306/jdbc_01";
String url = "jdbc:mysql://localhost:3306/jdbc_01?useUnicode=true&characterEncoding=UTF8";
//数据库用户名和密码
String user = "root";
String password = "88888888";
//与数据库建立连接
Connection con = DriverManager.getConnection(url,user,password);
//SQL语句执行机
Statement stmt = con.createStatement();
//结果集合
ResultSet rs;
//通过语句执行机stmt执行SQL的查询命令,返回到结果集rs中
rs = stmt.executeQuery("select * from user");
//从rs结果集合中获取信息
while(rs.next()){
int r_id = rs.getInt(1);
String r_username = rs.getString(2);
String r_password = rs.getString(3);
System.out.println(r_id+"\t用户名:"+r_username+"\t密码:"+r_password);
}
//依次关闭,先关闭最后启动的
rs.close();
stmt.close();
con.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
主要注意的是:
- 结果集合rs 中,next()方法相当于移动指针,不会读取数据,只会查看是否在新的指针位置中是否有数据。
- 这个ResultSet和iterator遍历器有相似之处。
- 调用结果集合rs的getInt()方法的时候,我们不仅可以直接传递columnIndex,还可以直接传递column的名字,如
rs.getInt("username")
输入返回:

和控制台(终端)的结果一样。

3-异常抛出
Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdbc.Driver'. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary.
意思是com.mysql.jdbc.Driver已经被弃用了,改为com.mysql.cj.jdbc.Driver即可。
第三章:优化JDBC程序
在当前位置调用close()关闭rs,stmt,con是不合理的。
如果上面的语句出现了异常,那么rs,stmt,con就不会关闭了。
把他们放在finally中。
并且把rs等对象的初始化放在try语句块的外部。
并且在关闭前查看一下对象是非为空。
import java.sql.*;
public class demo01 {
public static void main(String[] args) {
//与数据库建立连接
Connection con = null;
//SQL语句执行机
Statement stmt = null;
//结果集合
ResultSet rs = null;
try {
//注册驱动,使用该驱动连接数据库
// Class.forName("com.mysql.jdbc.Driver");
Class.forName("com.mysql.cj.jdbc.Driver");
//输入我们刚才创建的数据库名称
//String url = "jdbc:mysql://localhost:3306/jdbc_01";
String url = "jdbc:mysql://localhost:3306/jdbc_01?useUnicode=true&characterEncoding=UTF8";
//数据库用户名和密码
String user = "root";
String password = "88888888";
//与数据库建立连接
con = DriverManager.getConnection(url, user, password);
//SQL语句执行机
stmt = con.createStatement();
//通过语句执行机stmt执行SQL的查询命令,返回到结果集rs中
rs = stmt.executeQuery("select * from user");
//从rs结果集合中获取信息
while (rs.next()) {
int r_id = rs.getInt(1);
String r_username = rs.getString(2);
String r_password = rs.getString(3);
System.out.println(r_id + "\t用户名:" + r_username + "\t密码:" + r_password);
}
} catch (Exception e) {
e.printStackTrace();
} finally {
//依次关闭,先关闭最后启动的
try {
if (rs != null)
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
try {
if (stmt != null)
stmt.close();
} catch (SQLException e) {
e.printStackTrace();
}
try {
if (con != null)
con.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
【JDBC】学习路径2-编写第一个JDBC程序的更多相关文章
- JDBC 学习复习10 编写自己的JDBC框架
首先万分感谢狼哥 孤傲苍狼 博客,整个jdbc学习的博客资料 链接为http://www.cnblogs.com/xdp-gacl/p/4006830.html 详细代码见狼哥博客,列出我学习过程中遇 ...
- 一起学Hadoop——使用IDEA编写第一个MapReduce程序(Java和Python)
上一篇我们学习了MapReduce的原理,今天我们使用代码来加深对MapReduce原理的理解. wordcount是Hadoop入门的经典例子,我们也不能免俗,也使用这个例子作为学习Hadoop的第 ...
- 搭建java开发环境、使用eclipse编写第一个java程序
搭建java开发环境.使用eclipse编写第一个java程序 一.Java 开发环境的搭建 1.首先安装java SDK(简称JDK). 点击可执行文件 jdk-6u24-windows-i586. ...
- 【安装eclipse, 配置java环境教程】 编写第一个java程序
写java通常用eclipse编写,还有一款编辑器比较流行叫IJ.这里我们只说下eclipse编写java的前期工作. 在安装eclipse之前要下载java的sdk文件,即java SE:否则无法运 ...
- JavaWeb学习总结第二篇--第一个JavaWeb程序
JavaWeb学习总结第二篇—第一个JavaWeb程序 最近我在学院工作室学习并加入到研究生的项目中,在学长学姐的带领下,进入项目实践中,为该项目实现一个框架(用已有框架进行改写).于是我在这里记录下 ...
- Java笔记:编写第一个Java程序
2017.6.17 1.编写第一个Java程序 创建text文本,命名第一个Java程序.txt 在里面编写Java代码 public class Demo1{ public static void ...
- 假期作业02:安装JDK与文本编辑器并编写第一个Java程序
假期作业02:安装JDK与文本编辑器并编写第一个Java程序 一.安装JDK与文本编辑器并编写第一个java程序 首先在oracle官网(需要创建账号,进行登录后方可使用)按照自己的需求下载JDK(h ...
- 【C#入门教案-02】用记事本编写第一个C#程序-Hello World
02-用记事本编写第一个C#程序-Hello World 广东职业技术学院 欧浩源 [1]进行.NET程序开发的最基本环境配备 .NET Framework + 代码编辑工具(记事本或Noetpad ...
- 从零自学Java-1.编写第一个Java程序
编写第一个Java程序 完成工作:1.在文本编辑器中输入一个Java程序. 2.使用括号组织程序. 3.保存.编译和运行程序. package com.Jsample;//将程序的包名称命名为com. ...
随机推荐
- 从0到1搭建一款Vue可配置视频播放器组件(Npm已发布)
前言 话不多说,这篇文章主要讲述如何从0到1搭建一款适用于Vue.js的自定义配置视频播放器.我们平时在PC端网站上观看视频时,会看到有很多丰富样式的视频播放器,而我们自己写的video标签样式却是那 ...
- 梯度下降算法实现原理(Gradient Descent)
概述 梯度下降法(Gradient Descent)是一个算法,但不是像多元线性回归那样是一个具体做回归任务的算法,而是一个非常通用的优化算法来帮助一些机器学习算法求解出最优解的,所谓的通用就是很 ...
- CSS 盒子模型(一)
CSS 盒子模型(一) 本人在校学生,主学后端,后来发现前端的基础都忘得差不多了才想着写文章回来复习!欢迎留言交流. 什么是盒子呢? 拿下举例,我们可以把每个红框都比作一个盒子,他们可以是任意的 HT ...
- ArrayList集合概述和基本使用和ArrayList集合的常用方法和遍历
什么是ArrayList类 java.util.ArrayList 是大小可变的数组的实现,存储在内的数据称为元素.此类提供一些方法来操作内部存储 的元素. ArrayList 中可不断添加元素,其大 ...
- 开发实践丨昇腾CANN的推理应用开发体验
摘要:这是关于一次 Ascend 在线实验的记录,主要内容是通过网络模型加载.推理.结果输出的部署全流程展示,从而快速熟悉并掌握 ACL(Ascend Computing Language)基本开发流 ...
- day03 Java_运算符_分支结构
列表: 运算符的练习:算术.关系.逻辑.赋值.字符串连接.条件 分支结构的练习:if结构 分支结构的练习:if...else结构 参考 运算符的练习:算术 输出几个整数取模,验证结果 声明两个整型变量 ...
- Java开发学习(十四)----Spring整合Mybatis及Junit
一.Spring整合Mybatis思路分析 1.1 环境准备 步骤1:准备数据库表 Mybatis是来操作数据库表,所以先创建一个数据库及表 create database spring_db cha ...
- idea引入fastjson的jar包:ClassNotFound
idea 手动添加fastjson的jar包时,既在项目依赖里添加了,又在WEB-INF下的lib库里添加了 但是启动后就是加载不到,报错:ClassNotFound 尝试了好久,也参考了网上的许多建 ...
- 翟佳:高可用、强一致、低延迟——BookKeeper的存储实现
分享嘉宾:翟佳 StreamNative 联合创始人 编辑整理:张晓伟 美团点评 出品平台:DataFunTalk 导读:多数读者们了解BookKeeper是通过Pulsar,实际上BookKeepe ...
- 基于 Hexo 从零开始搭建个人博客(五)
阅读本篇前,请先阅读前几篇文章: 基于 Hexo 从零开始搭建个人博客(一) 基于 Hexo 从零开始搭建个人博客(二) 基于 Hexo 从零开始搭建个人博客(三) 基于 Hexo 从零开始搭建个人博 ...