Java调用Sql Server存储过程


  本文标签:Sql Server存储过程

  在使用Java开发时,经常会遇到调用Sql Server存储过程的问题,下面就为您示例介绍Java调用Sql Server存储过程的实现过程,希望可以帮助您解决Java调用Sql Server存储过程的难题  。

  1.数据库连接 

  1. package com.hujuan.conn;  
  2. import java.sql.Connection;  
  3. import java.sql.DriverManager;  
  4. import java.sql.SQLException;  
  5.  
  6. public  class DatabaseConn {  
  7.  
  8.    public static Connection getConnection(){  
  9.         String className"com.microsoft.jdbc.sqlserver.SQLServerDriver";  
  10.         String url = "jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=login";  
  11.         String name = "sa";  
  12.         String password = "sasa";  
  13.         try {  
  14.             Class.forName(className);  
  15.               
  16.             return DriverManager.getConnection(url,name,password);  
  17.         } catch (ClassNotFoundException e) {  
  18.             e.printStackTrace();  
  19.         } catch (SQLException e) {  
  20.             e.printStackTrace();  
  21.         }  
  22.         return null;  
  23.     }  
  24. }  

  2.通过连接调用存储过程

  1. package com.hujuan.dao;  
  2. import java.sql.CallableStatement;  
  3. import java.sql.Connection;  
  4. import java.sql.ResultSet;  
  5. import java.sql.SQLException;  
  6. import java.sql.Types;  
  7. import com.hujuan.conn.DatabaseConn;  
  8.  
  9. public class SqlServerProc {  
  10.  
  11.     public static void main(String[] args) {  
  12.         Connection conn = null;  
  13.         CallableStatement call = null;  
  14.         conn = DatabaseConn.getConnection();  
  15.  
  16.         try {  
  17.             call = conn.prepareCall("{call insertUserinfo(?,?,?,?)}");  
  18.             call.setString(1, "hujuan");  
  19.             call.setString(2, "女");  
  20.             call.setString(3, "1985-06-16");  
  21.             call.registerOutParameter(4, Types.INTEGER);  
  22.             call.executeUpdate();  
  23.             int value = call.getInt(4);  
  24.             System.out.println(value);  
  25.         } catch (SQLException e) {  
  26.             e.printStackTrace();  
  27.         }finally{  
  28.             try {  
  29.                 if(call != null)call.close();  
  30.                 if(conn != null)conn.close();  
  31.             } catch (SQLException e) {  
  32.                 e.printStackTrace();  
  33.             }  
  34.         }  
  35.           
  36.     }  
  37. }  

  返回结果集 

  1. package com.hujuan.dao;  
  2. import java.sql.CallableStatement;  
  3. import java.sql.Connection;  
  4. import java.sql.ResultSet;  
  5. import java.sql.SQLException;  
  6. import java.sql.Types;  
  7. import com.hujuan.conn.DatabaseConn;  
  8.  
  9. public class SqlServerProc {  
  10.  
  11.     public static void main(String[] args) {Connection conn = null;  
  12.         CallableStatement call = null;  
  13.         ResultSet rs = null;  
  14.         conn = DatabaseConn.getConnection();  
  15.  
  16.         try {  
  17.             call = conn.prepareCall("{?=call selectUserinfo()}");  
  18.             call.registerOutParameter(1, Types.REAL);  
  19.             rs = call.executeQuery();  
  20.             while(rs.next()){  
  21.                 System.out.println(rs.getString("name"));  
  22.             }  
  23.  
  24.         } catch (SQLException e) {  
  25.             e.printStackTrace();  
  26.         }finally{  
  27.             try {  
  28.                 if(rs != null)rs.close();  
  29.                 if(call != null)call.close();  
  30.                 if(conn != null)conn.close();  
  31.             } catch (SQLException e) {  
  32.                 e.printStackTrace();  
  33.             }  
  34.         }  
  35.     }  
  36.  
  37. }