文档章节

JDBC初步

pmos
 pmos
发布于 2016/08/11 23:30
字数 525
阅读 41
收藏 1

JDBC初步

1、下载MySQL的Connector

将Connector中的jar包加入到classpath中

2、创建Connection

			/*
			 * 1、创建Connection(注意是java.sql包中的Connection)
			 * 创建这个Connection需要指定相应的连接字符串和用户名和密码
			 * 注意:如果不加?useSSL=false或者?useSSL=true会有警告
			 */
			String url = "jdbc:mysql://localhost:3306/pm_test?useSSL=true";
			String user = "root";
			String password = "123456";
			con = DriverManager.getConnection(url, user, password);

3、编写SQL和执行SQL的Statement

			/*
			 * 2、创建SQL
			 * 执行SQL语句需要使用Statement
			 */
			String sql = "select * from t_dep";
			stat = con.createStatement();
			/*
			 * 在获取了stat之后,如果执行的是更新,直接使用stat.executeUpdate(sql)完成更新
			 * 如果执行的是查询,需要通过executeQuery(sql)完成,返回值是一个ResultSet的记录集
			 */

4、执行SQL,如果是查询就操作ResultSet

			//执行查询的情况
			rs = stat.executeQuery(sql);
			/*
			 * 遍历记录集的统一方式
			 */
			while(rs.next()) {
				System.out.println(rs.getInt("id")+","+rs.getString("name"));
				//也可以使用数据库查询出来的投影顺序访问,但是不建议使用该方式,因为投影顺序可能会在将来改变
				//所以一般都用投影的名称访问
//				System.out.println(rs.getInt(1)+","+rs.getString(2));
			}



			//执行更细的情况
//			String sql = "insert into t_dep (name) value ('教育系')";
			String sql = "update t_dep set name='政史系' where id=5";
			stat = con.createStatement();
			//通过stat完成更新
			stat.executeUpdate(sql);

5、释放资源

			/*
			 * 操作完成之后需要释放连接,先释放rs接着释放stat最后释放con
			 */
			try {
				if(rs!=null) rs.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}
			try {
				if(stat!=null) stat.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}
			try {
				if(con!=null) con.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}
		

PreparedStatement

如果直接使用Statement来执行SQL有可能会存在SQL注入的攻击,所以一般会使用PreparedStatement来替代Statement。

		Connection con = null;
		PreparedStatement ps = null;
		try {
			String url = "jdbc:mysql://localhost:3306/pm_test?useSSL=true";
			String user = "root";
			String password = "123456";
			con = DriverManager.getConnection(url, user, password);
			//使用PreparedStatement一般都是使用?来替代SQL中的变量
			String sql = "insert into t_spe (name,type,dep_id) value (?,?,?)";
			ps = con.prepareStatement(sql);
			//1表示设置第一个?的值
			ps.setString(1, "初等教育");
			ps.setString(2, "师范类");
			ps.setInt(3, 5);
			ps.executeUpdate();
		} catch (SQLException e) {
			e.printStackTrace();
		} finally {
			try {
				if(ps!=null) ps.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}
			try {
				if(con!=null) con.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}
		}

 

© 著作权归作者所有

共有 人打赏支持
pmos
粉丝 12
博文 123
码字总数 208836
作品 0
其它
项目经理
WebLogic时区与系统不一致的调整方式

我使用的WebLogic版本为9,运行环境为Windows7,WebLogic启动后发现控制台以及项目日志中的时间与实际系统的时间相差8小时,控制台显示的时区为GMT,于是考虑调整WebLogic的时区,查询WebLo...

benbenming
2011/07/12
0
0
Java学习---Java简单认识

前言 小编在学习Java方面的基础知识,发现里面有很多是结合之前的语言的特点发展过来的,不同的地方是,Java有它自己的发展和特点。下面小编先简单地做一下总结,结合看过的1-2章的J2SE视频,...

m18633778874
04/01
0
0
JAXB Annotation初步使用

JAXB(Java Architecture for XML Binding简称JAXB)允许Java开发人员将Java类映射为XML表示方式。JAXB提供两种主要特性:将一个Java对象序列化为XML,以及反向操作,将XML解析成Java对象。换...

秋风醉了
2014/07/02
0
0
Sharding-JDBC 3.0 即将发布,更名 Sharding-Sphere !

8日下午,知名开源数据库中间件 Sharding-JDBC 创始人张亮在朋友圈中发布了一个动态,表示 Sharding-JDBC 3.0 将于近期发布。 从该动态我们可以知道,从 3.0 开始,Sharding-JDBC 将更名为 ...

雨田桑
05/08
0
16
安装问题Error: dl failure on line 864

问题描述:在Linux RedHat5.5中安装的JDK1.7,并且通过在profile文件中修改JAVA_HOME,发现java -version命令依旧显示1.4版本,分析原因发现系统不按照profile的设定来执行java 命令,而是通...

datapro
2015/06/03
0
0

没有更多内容

加载失败,请刷新页面

加载更多

兄弟连区块链入门教程eth源码分析core-vm源码分析(二)

  兄弟连区块链入门教程eth源码分析core-vm源码分析(二),合约创建 Create 会创建一个新的合约。        // Create creates a new contract using code as deployment cod...

兄弟连区块链入门教程
11分钟前
0
0
python打造特别火的一个小游戏,16行代码实现3D撞球小游戏!

以下是制作上面炫酷动画所需的全部代码: 我们需要三组刚体(当您在Blender的对象上打开一个刚体的属性时,Blender将模拟与其它刚体的碰撞): 1.平面 第2行代码创建了一个简单的平面,立方体...

糖宝lsh
13分钟前
0
0
SQL语言分类

SQL(Structure Query Language)语言是数据库的核心语言。 SQL语言共分为四大类: 数据定义语言DDL,数据操纵语言DML,数据查询语言DQL,数据控制语言DCL。 数据定义语言DDL 数据定义语言DDL...

阿dai
16分钟前
1
0
UICollectionView的headerView、footerView使用以及与UITableView加载headerView、footerView的区别

前序 最近在一家公司实习,学习一些ios的知识。因为以前没有使用过UICollectionView,所以带我的导师让我仿照公司APP中的一个UICollectionView自己做一个练练手。期间遇到了一些问题:我们知...

壹峰
17分钟前
0
0
IMP-00017: following statement failed with ORACLE error 20005:

/*报错信息Export file created by EXPORT:V11.02.00 via conventional pathimport done in AL32UTF8 character set and AL16UTF16 NCHAR character setexport client uses ZHS16GBK char......

fengzhi714
21分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部