JDBC常用操作 (java 的数据库连接)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 1.常用类与方法 1.1连接 java.sql.Connection 代表与某一数据库的连接。 Connection java.sql.DriverManager.getConnection(String url, String user, String password)  用来连接数据库,URL由 jdbc:  +  ip:port  +dateBaseName组成,一

1.常用类与方法

1.1连接

java.sql.Connection

代表与某一数据库的连接。
Connection java.sql.DriverManager. getConnection(String url, String user, String password) 
用来连接数据库,URL由 jdbc:  +  ip:port  +dateBaseName组成,一个例子:
String url = "jdbc:mysql://115.28.321.123:3306/AliyunDB";
Statement java.sql.Connection. createStatement()
由Connection创建Statement。

1.2 编译/执行sql

1.2.1 Statement

java.sql. Statement
接口,用于执行sql语句并返回结果。定义见下:
public interface Statement extends Wrapper, AutoCloseable {...}
ResultSet java.sql.Statement. executeQuery(String sql) throws SQLException
执行sql查询并返回结果。这个方法被用来执行 SELECT 语句,它几乎是使用最多的 SQL 语句。
int java.sql.Statement. executeUpdate(String sql) 
用于执行INSERT, UPDATE, 或 DELETE等语句。返回值是一个整数,指示受影响的行数(即更新计数)。对于 CREATE TABLE 或 DROP TABLE 等不操作行的语句,executeUpdate 的返回值总为零。
void java.sql.Statement. setQueryTimeout(int seconds) throws SQLException
设置sql语句执行的超时时间。若超时,抛出SQLTimeoutException 异常。
void java.sql.Statement. setFetchSize(int rows)
设置一次性拿到结果的行数。若为0表示不限制。jdbc一次性查询rows行,放在内存中,这样rs.next()的时候没有网络通讯开销,当内存中的数据用完时再接着从服务端拿。
int[] java.sql.Statement. executeBatch() 
提交一批命令给数据库并让其执行。如果所有操作都成功,返回一个数组,大小与更新操作的个数一致。每个元素依次代表对应操作的更新行数。

1.2.2 PreparedStatement 

public interface PreparedStatement extends Statement {}
代表一个预编译的SQL语句,此对象可以多次执行这条SQl语句,只用替换变量即可。
void java.sql.PreparedStatement. addBatch() 
为当前对象的批处理命令增加一个参数集合。
void java.sql.PreparedStatement. setString(int parameterIndex, String x)
设置第parameterIndex个参数索引的内容为x。从1计数。
类似的,还有setInt、setDouble等。

1.3 取结果

java.sql.ResultSet

用于执行一个静态的SQL statement并返回结果。

boolean java.sql.ResultSet. next() throws SQLException
游标从当前行向下移。一个ResultSet对象的初始游标在第一行。

Object java.sql.ResultSet. getObject(int columnIndex) throws SQLException
获取ResultSet对象当前行指定列的信息。
String java.sql.ResultSet. getString(int columnIndex) throws SQLException
同上面的ResultSet.getObject类似,只不过返回是String类型。
String java.sql.ResultSet. getString( String arg0)
同上面的getString()类似,不过形参指定的是列名。
ResultSetMetaData java.sql.ResultSet. getMetaData() 
得到查询结果包含的ResultSetMetaData 。


java.sql. ResultSetMetaData
接口。表示一个ResultSet对象的列信息。
int java.sql.ResultSetMetaData. getColumnCount()
得到列数。
String java.sql.ResultSetMetaData. getColumnName(int column)
获取列名,从1计数。
String java.sql.ResultSetMetaData. getColumnLabel(int column)
获取列的标签,即 'select name as StudentName' 这样的语句,返回的就是"StudentName"。
int java.sql.ResultSetMetaData. getColumnType(int column)
获取列的类型。为int值,同java.sql. Types中的字段对应,包括int,varchar等。

2.事务

void java.sql.Connection.setAutoCommit(boolean autoCommit) throws SQLException
默认为自动提交模式,此时提交的语句都作为单独的事务执行。若设置为false,最后调用Connection.commit()提交,若失败可以Connection.rollback()回滚。

void java.sql.Connection.commit() throws SQLException
当setAutoCommit为false时才能用得到这个函数。
java.sql.Connection.rollback() throws SQLException
回滚当前事物的所有改动。

例子:

try{
	conn = DataSource.getConnection();String sql = "delete from xxTable";
	conn.setAutoCommit(false);st = conn.createStatement();
	num = st.executeUpdate(sql);conn.commit();
	}catch (Exception e) {
		 conn.rollback();
	}

3.存储过程

3.1 相关方法

java.sql. CallableStatement
用于执行存储过程的接口。是PreparedStatement的子接口,定义见下:
public interface CallableStatement extends PreparedStatement {...}
void java.sql.CallableStatement. setInt(String parameterName, int x) throws SQLException
将指定的参数设为 int 类型的x。
void java.sql.PreparedStatement. setInt(int parameterIndex, int x) 
别忘了还有这个继承自父类的方法。

CallableStatement java.sql.Connection. prepareCall(String sql) 
拿到CallableStatement对象,用于执行存储过程。

3.2 例子见下

/*创建存储过程*/
conn = getConnection();
//mysql dialect
String procedureSQL = "create procedure USER_EXIST(in loginName varchar(50),out amount int)" +  
            "begin select count(*) into amount from user where username = loginName ; end "; 
pstmt = conn.prepareStatement(procedureSQL);  
pstmt.executeUpdate();


/*调用存储过程*/
cstmt = conn.prepareCall("{call USER_EXIST(?,?)}");  
cstmt.setString(1, "小明");  
cstmt.registerOutParameter(2, Types.INTEGER); //注册输出参数  
cstmt.execute();  
System.out.println(cstmt.getInt(2)); //与上注册的对应  


4.工程

对于mysql,依赖配置为:

<dependency>
  	<groupId>mysql</groupId>
  	<artifactId>mysql-connector-java</artifactId>
  	<version>5.1.31</version>
</dependency>

对于SqlServer,依赖配置为:

<dependency>
	<groupId>com.microsoft.sqlserver</groupId>
	<artifactId>sqljdbc</artifactId>
	<version>4.0</version>
</dependency>



图3-1 表的结构

例1:JDBC使用

例2:PreparedStatement

//增添一项—— ip,ip解析后信息 ,当前时间
public void insertIP(String ip) throws SQLException{
		PreparedStatement preparedStatement = connection.prepareStatement("INSERT INTO `myTable` (ip,ip_info,date) VALUES(?,?,?)");
		String ipInfo = "中国,上海,上海,中国电信";
		DateFormat format1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");  
		String sqlDate=format1.format(new Date());
		preparedStatement.setString(1, ip);
		preparedStatement.setString(2, ipInfo);
		preparedStatement.setString(3, sqlDate);
		preparedStatement.execute();
	}

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
5月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
6月前
|
Java 关系型数据库 MySQL
Java汽车租赁系统源码(含数据库脚本)
Java汽车租赁系统源码(含数据库脚本)
105 4
|
6月前
|
NoSQL Java API
在Java环境下如何进行Redis数据库的操作
总的来说,使用Jedis在Java环境下进行Redis数据库的操作,是一种简单而高效的方法。只需要几行代码,就可以实现复杂的数据操作。同时,Jedis的API设计得非常直观,即使是初学者,也可以快速上手。
275 94
|
7月前
|
SQL Java 数据库连接
【YashanDB数据库】由于网络带宽不足导致的jdbc向yashandb插入数据慢
由于网络带宽不足导致的jdbc向yashandb插入数据慢
|
7月前
|
SQL druid Oracle
【YashanDB知识库】yasdb jdbc驱动集成druid连接池,业务(java)日志中有token IDENTIFIER start异常
客户Java日志中出现异常,影响Druid的merge SQL功能(将SQL字面量替换为绑定变量以统计性能),但不影响正常业务流程。原因是Druid在merge SQL时传入null作为dbType,导致无法解析递归查询中的`start`关键字。
|
7月前
|
SQL Java 中间件
【YashanDB知识库】yasdb jdbc驱动集成BeetISQL中间件,业务(java)报autoAssignKey failure异常
在BeetISQL 2.13.8版本中,客户使用batch insert向yashandb表插入数据并尝试获取自动生成的sequence id时,出现类型转换异常。原因是beetlsql在prepareStatement时未指定返回列,导致yashan JDBC驱动返回rowid(字符串),与Java Bean中的数字类型tid不匹配。此问题影响业务流程,使无法正确获取sequence id。解决方法包括:1) 在batchInsert时不返回自动生成的sequence id;2) 升级至BeetISQL 3,其已修正该问题。
【YashanDB知识库】yasdb jdbc驱动集成BeetISQL中间件,业务(java)报autoAssignKey failure异常
|
7月前
|
前端开发 JavaScript Java
[Java计算机毕设]基于ssm的OA办公管理系统的设计与实现,附源码+数据库+论文+开题,包安装调试
OA办公管理系统是一款基于Java和SSM框架开发的B/S架构应用,适用于Windows系统。项目包含管理员、项目管理人员和普通用户三种角色,分别负责系统管理、请假审批、图书借阅等日常办公事务。系统使用Vue、HTML、JavaScript、CSS和LayUI构建前端,后端采用SSM框架,数据库为MySQL,共24张表。提供完整演示视频和详细文档截图,支持远程安装调试,确保顺利运行。
255 17
|
8月前
|
存储 缓存 Java
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
807 3
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
|
8月前
|
人工智能 JavaScript 关系型数据库
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
246 14
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
|
8月前
|
人工智能 JavaScript 安全
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
314 13
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战