前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >第一个JDBC程序

第一个JDBC程序

作者头像
星哥玩云
发布2022-09-14 20:36:47
发布2022-09-14 20:36:47
28600
代码可运行
举报
文章被收录于专栏:开源部署开源部署
运行总次数:0
代码可运行

一、准备驱动

准备mysql数据库的驱动jar包:mysql-connector-java-5.1.13-bin.jar;

二、获取连接

​ 获取连接需要两步:

​ 一是使用DriverManager来注册驱动

​ 二是使用DriverManager来获取Connection对象(连接对象)。

注册驱动

看清楚了,注册驱动就只有一句话:Class.forName(“com.mysql.jdbc.Driver”),下面的内容都是对这句代码的解释。今后我们的代码中,与注册驱动相关的代码只有这一句。

DriverManager类的registerDriver()方法的参数是java.sql.Driver,但java.sql.Driver是一个接口,实现类由mysql驱动来提供,mysql驱动中的java.sql.Driver接口的实现类为com.mysql.jdbc.Driver!那么注册驱动的代码如下:

​ DriverManager.registerDriver(new com.mysql.jdbc.Driver());

上面代码虽然可以注册驱动,但是出现硬编码(代码依赖mysql驱动jar包),如果将来想连接Oracle数据库,那么必须要修改代码的。并且其实这种注册驱动的方式是注册了两次驱动!

JDBC中规定,驱动类在被加载时,需要自己“主动”把自己注册到DriverManger中,下面我们来看看com.mysql.jdbc.Driver类的源代码:

com.mysql.jdbc.Driver.java

代码语言:javascript
代码运行次数:0
运行
复制
public class Driver extends NonRegisteringDriver implements java.sql.Driver {
	static {
		try {
			java.sql.DriverManager.registerDriver(new Driver());
		} catch (SQLException E) {
			throw new RuntimeException("Can't register driver!");
		}
	}
……
}

com.mysql.jdbc.Driver类中的static块会创建本类对象,并注册到DriverManager中。这说明只要去加载com.mysql.jdbc.Driver类,那么就会执行这个static块,从而也就会把com.mysql.jdbc.Driver注册到DriverManager中,所以可以把注册驱动类的代码修改为加载驱动类

Class.forName(“com.mysql.jdbc.Driver”);

获取连接

获取连接的也只有一句代码:DriverManager.getConnection(url,username,password),其中username和password是登录数据库的用户名和密码,如果我没说错的话,你的mysql数据库的用户名和密码分别是:root、123。

url相对复杂一点,它是用来找到要连接数据库“网址”,就好比你要浏览器中查找百度时,也需要提供一个url。下面是mysql的url:

jdbc:mysql://localhost:3306/mydb1

JDBC规定url的格式由三部分组成,每个部分中间使用逗号分隔。

​ 第一部分是jdbc,这是固定的;

​ 第二部分是数据库名称,那么连接mysql数据库,第二部分当然是mysql了;

​ 第三部分是由数据库厂商规定的,我们需要了解每个数据库厂商的要求,mysql的第三部分分别由数据库服务器的IP地址(localhost)、端口号(3306),以及**DATABASE名称(mydb1)**组成。

下面是获取连接的语句:

Connection con = DriverManager.getConnection(“jdbc:mysql://localhost:3306/mydb1”,”root”,”123”);

还可以在url中提供参数:

jdbc:mysql://localhost:3306/mydb1**?useUnicode=true&characterEncoding=UTF8**

useUnicode参数指定这个连接数据库的过程中,使用的字节集是Unicode字节集;

characherEncoding参数指定连接数据库的过程中,使用的字节集编码为UTF-8编码。请注意,mysql中指定UTF-8编码是给出的是UTF8,而不是UTF-8。要小心了!

三、获取Statement

在得到Connectoin之后,说明已经与数据库连接上了,下面是通过Connection获取Statement对象的代码:

Statement stmt = con.createStatement();

Statement是用来向数据库发送要执行的SQL语句的!

四、发送SQL增、删、改语句

定义sql语句

String sql = “insert into user value(’zhangSan’, ’123’)”;

执行增删改的方法:executeUpdate(String sql)

int m = stmt.executeUpdate(sql);

其中int类型的返回值表示执行这条SQL语句所影响的行数,我们知道,对insert来说,最后只能影响一行,而update和delete可能会影响0~n行。

如果SQL语句执行失败,那么executeUpdate()会抛出一个SQLException。

五、发送SQL查询语句

定义sql语句

String sql = “select * from user”;

执行查询语句

ResultSet rs = stmt.executeQuery(sql);

请注册,执行查询使用的不是executeUpdate()方法,而是executeQuery()方法。executeQuery()方法返回的是ResultSet,ResultSet封装了查询结果,我们称之为结果集。

六、读取结果集中的数据

ResultSet就是一张二维的表格,它内部有一个“行光标”,光标默认的位置在“第一行上方”,我们可以调用rs对象的next()方法把“行光标”向下移动一行,当第一次调用next()方法时,“行光标”就到了第一行记录的位置,这时就可以使用ResultSet提供的getXXX(int col)方法来获取指定列的数据了:

rs.next();//光标移动到第一行

rs.getInt(1);//获取第一行第一列的数据

当你使用rs.getInt(1)方法时,你必须可以肯定第1列的数据类型就是int类型,如果你不能肯定,那么最好使用rs.getObject(1)。在ResultSet类中提供了一系列的getXXX()方法,比较常用的方法有:

Object getObject(int col)

String getString(int col)

int getInt(int col)

double getDouble(int col)

七、关闭

与IO流一样,使用后的东西都需要关闭!关闭的顺序是先得到的后关闭,后得到的先关闭。

rs.close();

stmt.close();

con.close();

八、代码实现

获取连接的方法

代码语言:javascript
代码运行次数:0
运行
复制
	public static Connection getConnection() throws Exception {
		Class.forName("com.mysql.jdbc.Driver");
		String url = "jdbc:mysql://localhost:3306/mydb1";
		return DriverManager.getConnection(url, "root", "poi");
	}

执行插入的方法

代码语言:javascript
代码运行次数:0
运行
复制
	@Test
	public static void insert() throws Exception {
		Connection con = getConnection();
		Statement stmt = con.createStatement();
		String sql = "insert into user values('zhangSan', '123')";
		stmt.executeUpdate(sql);
		System.out.println("插入成功!");
	}

执行更新的方法

代码语言:javascript
代码运行次数:0
运行
复制
	@Test
	public static void update() throws Exception {
		Connection con = getConnection();
		Statement stmt = con.createStatement();
		String sql = "update user set password='456' where 						username='zhangSan'";
		stmt.executeUpdate(sql);
		System.out.println("修改成功!");
	}

执行删除的方法

代码语言:javascript
代码运行次数:0
运行
复制
	@Test
	public static void delete() throws Exception {
		Connection con = getConnection();
		Statement stmt = con.createStatement();
		String sql = "delete from user where username='zhangSan'";
		stmt.executeUpdate(sql);
		System.out.println("删除成功!");
	}

执行查询的方法

代码语言:javascript
代码运行次数:0
运行
复制
	@Test
	public static void query() throws Exception {
		Connection con = getConnection();
		Statement stmt = con.createStatement();
		String sql = "select * from user";
		ResultSet rs = stmt.executeQuery(sql);
		while(rs.next()) {
			String username = rs.getString(1);
			String password = rs.getString(2);
			System.out.println(username + ", " + password);
		}
	}

九、规范化代码

所谓规范化代码就是无论是否出现异常,都要关闭ResultSet、Statement,以及Connection,如果你还记得IO流的规范化代码,那么下面的代码你就明白什么意思了。

代码语言:javascript
代码运行次数:0
运行
复制
@Test
	public void query() {
		Connection con = null;
		Statement stmt = null;
		ResultSet rs = null;
 		try {
			con = getConnection(); 
			stmt = con.createStatement();
			String sql = "select * from user";
			rs = stmt.executeQuery(sql);
			while(rs.next()) {
				String username = rs.getString(1);
				String password = rs.getString(2);
				System.out.println(username + ", " + password);
			}
		} catch(Exception e) {
			throw new RuntimeException(e);
		} finally {
			try {
				if(rs != null) rs.close();
				if(stmt != null) stmt.close();
				if(con != null) con.close();
 			} catch(SQLException e) {
                //throw new RuntimeException(e);
                e.printStackTrace();
            }
		}
	}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、准备驱动
  • 二、获取连接
  • 三、获取Statement
  • 四、发送SQL增、删、改语句
  • 五、发送SQL查询语句
  • 六、读取结果集中的数据
  • 七、关闭
  • 八、代码实现
  • 九、规范化代码
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档