execute、executeUpdate、executeQuery三者的区别(及返回值)

本文详细解释了execute、executeUpdate与executeQuery三个SQL执行方法的区别及其返回值。execute可用于执行多种类型的SQL语句,并通过返回值区分查询与更新操作;executeUpdate专门用于执行更新语句并返回受影响的记录数;executeQuery则专门用于执行查询语句并返回结果集。

一、boolean execute(String sql)

允许执行查询语句、更新语句、DDL语句。

返回值为true时,表示执行的是查询语句,可以通过getResultSet方法获取结果;返回值为false时,执行的是更新语句或DDL语句,getUpdateCount方法获取更新的记录数量。

例子:

[Java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. <span style="font-size: 16px;"><strong>public static void main(String[] args) {  
  2.   
  3.   Connection conn = null;  
  4.   Statement stm = null;  
  5.   ResultSet rs = null;  
  6.   try {  
  7.    Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");  
  8.    conn = DriverManager.getConnection("jdbc:sqlserver://localhost:1433;databaseName=Test;user=sa;password=sasa");  
  9.    stm = conn.createStatement();  
  10.    boolean ret = stm.execute("select * from stuinfo");  
  11.    if(ret){  
  12.     rs = stm.getResultSet();  
  13.     while(rs.next()){  
  14.      System.out.println("姓名:"+rs.getString("stuName")+"\t年龄:"+rs.getString("stuScore"));  
  15.     }  
  16.    }  
  17.    ret = stm.execute("update stuinfo set stuScore=62 where stuname='张三'");  
  18.    int count = stm.getUpdateCount();  
  19.    if(!ret){  
  20.     System.out.println(count+"条数据修改成功!");  
  21.    }  
  22.   } catch (ClassNotFoundException e) {  
  23.    e.printStackTrace();  
  24.   } catch (SQLException e) {  
  25.    e.printStackTrace();  
  26.   }    
  27.  }</strong></span>  

二、int executeUpdate(String sql)

执行给定 SQL 语句,该语句可能为 INSERT、UPDATE 或 DELETE 语句,或者不返回任何内容的 SQL 语句(如 SQL DDL 语句)。

返回值是更新的记录数量

三、ResultSet executeQuery(String sql)

执行给定的 SQL 语句,该语句返回单个 ResultSet 对象。


execute是executeUpdate与executeQuery的综合

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值