文档章节

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
Sharding-JDBC 3.0 即将发布,更名 Sharding-Sphere !

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

雨田桑
05/08
0
16
JAXB Annotation初步使用

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

秋风醉了
2014/07/02
0
0
安装问题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

没有更多内容

加载失败,请刷新页面

加载更多

下一页

002,zabbix-agent的安装 监控Linux主机

2.1.安装zabbix-agent $ rpm -i http://repo.zabbix.com/zabbix/3.4/rhel/7/x86_64/zabbix-release-3.4-2.el7.noarch.rpm$ yum install -y zabbix-agent zabbix-get 2.2.配置zabbix-agent ......

happyeveryday32
34分钟前
2
0
docker learn :swarm

swarm是什么 swarm是一组运行docker服务的集群,之后,还是使用那些命令去操作docker,但是是通过swarm manager来执行的。 swarm中的机器可以是实体的也可以是虚拟的,加入swarm后,他们被当作...

writeademo
34分钟前
1
0
Golang + vscode 开发环境配置

GOPATH 环境变量的配置 https://my.oschina.net/xinxingegeya/blog/718305 安装vscode go 扩展 下载vscode ,安装go的扩展https://github.com/Microsoft/vscode-go 该扩展对 Golang 支持非常......

秋风醉了
37分钟前
0
0
idea jar包

我自己用idea新建一个springboot项目,打包一直有问题,百度了下,又总结了下。 方式一: 找到Project Structure菜单,然后点开,照下图点击 然后出现下图所示 红框1:为你项目的main函数所在...

朝如青丝暮成雪
38分钟前
0
0
Vue scoped CSS 与深度作用选择器 /deep/

使用 scoped 后,父组件的样式将不会渗透到子组件中。 例如(无效): <template> <div id="app"> <el-input class="text-box" v-model="text"></el-input> </div></template><......

不负好时光
38分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部