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>
目录
相关文章
|
4月前
|
Java 开发工具
【Azure Storage Account】Java Code访问Storage Account File Share的上传和下载代码示例
本文介绍如何使用Java通过azure-storage-file-share SDK实现Azure文件共享的上传下载。包含依赖引入、客户端创建及完整示例代码,助你快速集成Azure File Share功能。
428 5
|
5月前
|
IDE Java 关系型数据库
Java 初学者学习路线(含代码示例)
本教程为Java初学者设计,涵盖基础语法、面向对象、集合、异常处理、文件操作、多线程、JDBC、Servlet及MyBatis等内容,每阶段配核心代码示例,强调动手实践,助你循序渐进掌握Java编程。
705 3
|
5月前
|
Java
java入门代码示例
本文介绍Java入门基础,包含Hello World、变量类型、条件判断、循环及方法定义等核心语法示例,帮助初学者快速掌握Java编程基本结构与逻辑。
499 0
Java API 开发者
169 0
|
7月前
|
安全 Java 网络安全
Java 实现 SMTP 协议调用的详细示例及实战指南 SMTP Java 调用示例
本文介绍了如何使用Java调用SMTP协议发送邮件,涵盖SMTP基本概念、JavaMail API配置、代码实现及注意事项,适合Java开发者快速掌握邮件发送功能集成。
822 0
|
7月前
|
算法 搜索推荐 Java
Java中的Collections.shuffle()方法及示例
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的方法,基于 Fisher-Yates 算法实现,支持原地修改。可选传入自定义 `Random` 对象以实现结果可重复,适用于抽奖、游戏、随机抽样等场景。
305 0
|
8月前
|
存储 安全 Java
应届生面试高频 Java 基础问题及实操示例解析
本文总结了Java基础面试中的高频考点,包括数据类型分类、final修饰符的三种用途、static关键字特性、==与equals的区别、Java只有值传递的特性、String的不可变性、Error与Exception的差异、程序初始化顺序规则,以及IO流的字节流/字符流分类。每个问题都配有简明定义和典型示例,如用final修饰变量示例、static方法调用限制说明等,帮助应聘者快速掌握核心概念和实际应用场景。
197 0
|
8月前
|
Java 关系型数据库 MySQL
2025 年互联网公司校招 Java 面试题总结及答案实操示例解析
本项目基于Spring Boot 3与Java 17技术栈,围绕校园招聘常见面试题,提供核心知识点的实操示例。涵盖多线程、RESTful API设计、数据库操作(Spring Data JPA)、事务管理及异常处理等。通过完整代码实现与运行步骤,帮助理解用户管理、线程池配置等实际应用场景。资源包含项目结构、关键代码示例(如User实体类、UserService服务层、ThreadService多线程实现)及数据库迁移脚本,适合深入学习与实践。环境要求:JDK 17+、Maven 3.8+、MySQL 8.0+。
292 3
|
9月前
|
存储 SQL 数据库连接
C#程序调用Sql Server存储过程异常处理:调用存储过程后不返回、不抛异常的解决方案
本文分析了C#程序操作Sql Server数据库时偶发的不返回、不抛异常问题,并提出了解决思路。首先解析了一个执行存储过程的函数`ExecuteProcedure`,其功能是调用存储过程并返回影响行数。针对代码执行被阻塞但无异常的情况,文章总结了可能原因,如死锁、无限循环或网络问题等。随后提供了多种解决方案:1) 增加日志定位问题;2) 使用异步操作提升响应性;3) 设置超时机制避免阻塞;4) 利用线程池分离主线程;5) 通过信号量同步线程;6) 监控数据库连接状态确保可用性。这些方法可有效应对数据库操作中的潜在问题,保障程序稳定性。
714 11