网页资讯视频图片知道文库贴吧地图采购
进入贴吧全吧搜索

 
 
 
日一二三四五六
       
       
       
       
       
       

签到排名:今日本吧第个签到,

本吧因你更精彩,明天继续来努力!

本吧签到人数:0

一键签到
成为超级会员,使用一键签到
一键签到
本月漏签0次!
0
成为超级会员,赠送8张补签卡
如何使用?
点击日历上漏签日期,即可进行补签。
连续签到:天  累计签到:天
0
超级会员单次开通12个月以上,赠送连续签到卡3张
使用连续签到卡
11月28日漏签0天
广东信息科技职业...吧 关注:1,716贴子:17,645
  • 看贴

  • 图片

  • 吧主推荐

  • 游戏

  • 0回复贴,共1页
<<返回广东信息科...吧
>0< 加载中...

JAVA笔记——JDBC获取存储过程和主键

  • 只看楼主
  • 收藏

  • 回复
  • 可爱的林顺扬
  • 初涉江湖
    1
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
获取数据库自动生成的主键:
update 更新操作以后,如果需要用到结果集,可以通过 PreparedStatement.getResultSet()方法获得结果集;
getGeneratedKeys(); 获取执行完插入语句后自动生成的键,结果封装在一个结果集里面;
PreparedStatement 对象,进行预编译的时候,可以接受2个参数,第二个参数表示是自动获得自动生成的键。
获得的结果,封装在一个结果集里面。然后调用 PreparedStatement.getGeneratedKeys(); 拿到这个结果集;
代码演示:
Connectionconnection = null;
PreparedStatement statement= null;
ResultSet resultSet = null;
try {
connection =JdbcUtils.getConnection();
String sql ="INSERT INTO testBlob(image) VALUES(?)";
// 接受2个参数,第二个参数,是否自动获得自动生成的键
Statement = connection.prepareStatement(sql,Statement.RETURN_GENERATED_KEYS);
File file = newFile("src/ijava/xin/images/th2.jpg");
InputStream inputStream= new FileInputStream(file);
statement.setBinaryStream(1, inputStream);
int num =statement.executeUpdate();
if(num>0){
// 获取封装了自动生成的键的结果集
resultSet =statement.getGeneratedKeys() ;
if(resultSet.next()){
System.out.println(resultSet.getInt(1));
}
}
} catch (Exception e) {
e.printStackTrace();
} finally {
JdbcUtils.closedConnection(resultSet, statement, connection);
}
上述的操作,仅对 insert 有效,毕竟只有插入操作,才会生成键;
JDBC调用存储过程:
存储过程就是相当于方法一样,只是这个方法是数据里面的方法,可以理解为数据库里面的处理数据的方法;
首先需要先获得 CallableStatement 对象,并调用存储过程, 设置参数注册返回值,得到输出;
CallableStatementcStmt = conn.prepareCall("{call demoSp(?,?)}") ; // 参数是存储过程的名字;
// 设置参数
cStmt.setString(1,"abcdef") ;
// 告诉mysql,存储过程的第二个参数是字符串
cStmt.registerOutParameter(2,Type.VARCHAR) ;
// 执行存储过程
// 获取存储过程的返回结果
Sout(cStmt.getString(2)) ;


登录百度账号

扫二维码下载贴吧客户端

下载贴吧APP
看高清直播、视频!
  • 贴吧页面意见反馈
  • 违规贴吧举报反馈通道
  • 贴吧违规信息处理公示
  • 0回复贴,共1页
<<返回广东信息科...吧
分享到:
©2025 Baidu贴吧协议|隐私政策|吧主制度|意见反馈|网络谣言警示