Java调用Sql Server存储过程

数据库 SQL Server
使用不同的开发语言进行开发的过程中,都会遇到调用Sql Server存储过程的时候。下文对Java调用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. }  

 

 

 

 

【编辑推荐】

使用SQL Server视图的优缺点

SQL Server排序规则的应用

带您了解SQL Server标识列

SQL Server UPDATE语句的用法

SQL Server添加列及删除列

责任编辑:段燃 来源: 互联网
相关推荐

2012-05-10 11:17:23

JavaSQL Server

2011-06-17 17:37:16

JavaSQL Server

2010-11-10 15:16:14

Sql Server分

2010-01-22 16:48:54

VB.NET调用SQL

2011-08-22 10:15:39

数据库存储过程

2009-08-06 16:44:06

2010-07-26 14:43:31

SQL Server存

2011-09-01 13:43:23

VC调用SQL Ser

2011-08-29 15:52:19

SQL ServerMybatis存储过程

2010-07-15 12:38:14

SQL Server存

2010-07-23 14:26:37

SQL Server存

2011-03-24 13:38:47

SQL Server 存储分页

2010-09-14 10:16:57

sql server

2010-09-14 10:36:23

sql server存

2011-03-28 10:46:36

sql server存储分页

2009-11-11 13:38:04

ADO.NET sql

2009-06-19 16:22:55

Java存储过程

2010-06-28 09:21:04

SQL Server存

2010-07-06 14:06:52

SQL Server存

2010-07-05 10:06:51

SQL Server扩
点赞
收藏

51CTO技术栈公众号