Java中调用SQL Server存储过程示例

简介:   最近做了个Java的小项目(第一次写Java的项目哦), 到网上搜索了半天,找到了一个比较好点的调用存储过程的例子,而且网上普遍采用的都是setXXX((int parameterIndex, XXX x)的形式。
  最近做了个 Java的小项目(第一次写Java的项目哦), 到网上搜索了半天,找到了一个比较好点的调用存储过程的例子,而且网上普遍采用的都是setXXX((int parameterIndex, XXX x)的形式。这种形式感觉不是很直观,下面就发布一个完整的采用setXXX(String parameterName, XXX x)的编写方法。创建数据表,存储过程的代码都完整发布。

  创建表:

CREATE   TABLE   [ BookUser ]  (
    
[ UserID ]   [ int ]   IDENTITY  ( 1 1 NOT   NULL  ,
    
[ UserName ]   [ varchar ]  ( 50 ) COLLATE Chinese_PRC_CI_AS  NOT   NULL  ,
    
[ Title ]   [ nvarchar ]  ( 50 ) COLLATE Chinese_PRC_CI_AS  NOT   NULL  ,
    
[ Guid ]   [ uniqueidentifier ]   NOT   NULL   CONSTRAINT   [ DF_BookUser_Guid ]   DEFAULT  ( newid ()),
    
[ BirthDate ]   [ datetime ]   NOT   NULL  ,
    
[ Description ]   [ ntext ]  COLLATE Chinese_PRC_CI_AS  NOT   NULL  ,
    
[ Photo ]   [ image ]   NULL  ,
    
[ Other ]   [ varchar ]  ( 50 ) COLLATE Chinese_PRC_CI_AS  NULL   CONSTRAINT
          
[ DF_BookUser_Other ]   DEFAULT  ( ' 默认值 ' ),
    
CONSTRAINT   [ PK_BookUser ]   PRIMARY   KEY    CLUSTERED  
    (
        
[ UserID ]
    )  
ON   [ PRIMARY ]  
ON   [ PRIMARY ]  TEXTIMAGE_ON  [ PRIMARY ]
GO

  创建存储过程:

CREATE   PROCEDURE  InsertUser
@UserName   varchar ( 50 ),
@Title   varchar ( 255 ),
@Guid    uniqueidentifier ,
@BirthDate   DateTime ,
@Description   ntext ,
@Photo   image ,
@Other   nvarchar ( 50 ),
@UserID   int  output 
As

Set  NOCOUNT  ON
If   Exists  ( select  UserID  from  BookUser  Where  UserName  =   @UserName )
RETURN   0
ELSE
Begin
INSERT   INTO  BookUser (UserName,Title,Guid,BirthDate,Description,Photo,Other)  VALUES ( @UserName , @Title , @Guid , @BirthDate , @Description , @Photo , @Other )
SET   @UserID   =   @@IDENTITY
RETURN   1
End
GO

  JSP代码:

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ page import = "java.sql.*"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
</head>
<body>
<%
//注意:下面的连接方法采用最新的SQL Server的JDBC,
//请到 http://msdn2.microsoft.com/zh-cn/data/aa937724.aspx 下载
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
String url="jdbc:sqlserver://localhost:1433;databaseName=Book;user=sa;password=";
String sql = "{? = call InsertUser(?,?,?,?,?,?,?,?)}";
Connection cn = null;
CallableStatement cmd = null;
try
{
 cn = DriverManager.getConnection(url);
 cmd = cn.prepareCall(sql);
 java.util.UUID Guid = java.util.UUID.randomUUID();
 String FilePath = application.getRealPath("") + "/test/logo.gif";
 java.io.FileInputStream f = new java.io.FileInputStream(FilePath);
 Date rightNow = Date.valueOf("2007-9-9");
 cmd.setString("UserName","mengxianhui"); //注意修改这里,存储过程验证了UserName的唯一性。
 cmd.setString("Title","孟宪会");
 cmd.setString("Guid",Guid.toString());
 cmd.setString("BirthDate","2007-9-9");
 cmd.setDate("BirthDate",rightNow);
 cmd.setString("Description","【孟子E章】");
 cmd.setBinaryStream("Photo",f,f.available());
 cmd.setString("Other",null);
 cmd.registerOutParameter(1,java.sql.Types.INTEGER);
 cmd.registerOutParameter("UserID",java.sql.Types.INTEGER);
 cmd.execute();
 int returnValue = cmd.getInt(1);
 int UserID = cmd.getInt("UserID");
 if(returnValue == 1)
 {
  out.print("<li>添加成功!");
  out.print("<li>UserID = " + UserID);
  out.print("<li>returnValue = " + returnValue);
 }
 else
 {
  out.print("<li>添加失败!");
 }
 f.close();
}
catch(Exception ex)
{
 out.print(ex.getLocalizedMessage());
}
finally
{
 try
 {
  if(cmd != null) 
  {
   cmd.close();
   cmd = null;
  }
  if(cn != null)
  {
   cn.close();
   cn = null;
  }
 }
 catch(Exception e)
 {
  e.printStackTrace();
 }
}
%>
</body>
</html>
目录
相关文章
|
存储 SQL 数据库
SQL Server存储过程的优缺点
【10月更文挑战第18天】SQL Server 存储过程具有提高性能、增强安全性、代码复用和易于维护等优点。它可以减少编译时间和网络传输开销,通过权限控制和参数验证提升安全性,支持代码共享和复用,并且便于维护和版本管理。然而,存储过程也存在可移植性差、开发和调试复杂、版本管理问题、性能调优困难和依赖数据库服务器等缺点。使用时需根据具体需求权衡利弊。
363 1
|
9月前
|
存储 SQL 数据库连接
C#程序调用Sql Server存储过程异常处理:调用存储过程后不返回、不抛异常的解决方案
本文分析了C#程序操作Sql Server数据库时偶发的不返回、不抛异常问题,并提出了解决思路。首先解析了一个执行存储过程的函数`ExecuteProcedure`,其功能是调用存储过程并返回影响行数。针对代码执行被阻塞但无异常的情况,文章总结了可能原因,如死锁、无限循环或网络问题等。随后提供了多种解决方案:1) 增加日志定位问题;2) 使用异步操作提升响应性;3) 设置超时机制避免阻塞;4) 利用线程池分离主线程;5) 通过信号量同步线程;6) 监控数据库连接状态确保可用性。这些方法可有效应对数据库操作中的潜在问题,保障程序稳定性。
716 11
|
存储 SQL 缓存
SQL Server存储过程的优缺点
【10月更文挑战第22天】存储过程具有代码复用性高、性能优化、增强数据安全性、提高可维护性和减少网络流量等优点,但也存在调试困难、移植性差、增加数据库服务器负载和版本控制复杂等缺点。
582 1
|
存储 SQL 数据库
Sql Server 存储过程怎么找 存储过程内容
Sql Server 存储过程怎么找 存储过程内容
771 1
|
5月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1042 152
|
5月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
817 156
|
5月前
|
SQL 人工智能 Linux
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
547 5
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
|
10月前
|
SQL 数据库 数据安全/隐私保护
数据库数据恢复——sql server数据库被加密的数据恢复案例
SQL server数据库数据故障: SQL server数据库被加密,无法使用。 数据库MDF、LDF、log日志文件名字被篡改。 数据库备份被加密,文件名字被篡改。
|
5月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
6月前
|
SQL 人工智能 Linux
SQL Server 2025 RC0 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC0 发布 - 从本地到云端的 AI 就绪企业数据库
339 5