当前位置:首页 > 芯闻号 > 充电吧
[导读]                        我所写的项目是使用Maven开发,在pom.xml中添加如下必要依赖:         添加com.microsoft.sqlserver的mssql-

               

        我所写的项目是使用Maven开发,在pom.xml中添加如下必要依赖:
        添加com.microsoft.sqlserver的mssql-jdbc 6.2.1.jre8的依赖

  
    com.microsoft.sqlserver  
    mssql-jdbc  
    6.2.1.jre8  
 

        

        在下面的Java代码块中,涉及到如何在Java中创建SQL Server的“表值变量”(临时表),以及Java代码如何去调用SQL Server的存储过程,如何传递在Java代码中所写的“表值变量”(临时表)。其中,代码中所调用的 proc_test01存储过程,可参考我写的博客:SQL Server数据库学习之 -- 存储过程-游标-表值类型综合运用

       

       我所写的代码有些简化,以“学生 -- 班级 -- 教师”这种经典模式来讲解自己所运用的知识点。可能网友直接将我的代码粘贴-复制,运行会报错。不过其中的知识点确是无误的!


        在本篇文章中,最重要的是其运用到SQL Server表值类型变量这块知识。关于在Java代码中引入的Sql Server-Jar包,不能太低,否则无法使用“表值类型变量”这块知识。 

import java.util.Map;

import com.microsoft.sqlserver.jdbc.SQLServerCallableStatement;
import com.microsoft.sqlserver.jdbc.SQLServerDataTable;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.dao.DataAccessException;
import org.springframework.jdbc.core.CallableStatementCallback;
import org.springframework.jdbc.core.CallableStatementCreator;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Service;

@Service
public class ClazzService {
        /**
	 * 批量提交班级信息
	 */
	public int putClazz(Clazz clazz) throws SQLException {
		Integer count = 0;  
		
		Integer testCount = sqlServerJdbcTemplate.execute(
				new CallableStatementCreator() {
					@Override
					public CallableStatement createCallableStatement(Connection con) throws SQLException {
						SQLServerCallableStatement cs = (SQLServerCallableStatement) con.prepareCall("exec proc_test01 ?, ?");
						// 设置存储过程中所用的临时表名
						SQLServerDataTable sourceDataTable = new SQLServerDataTable();
						
						// 为临时表sourceDataTable添加表头字段和字段类型
						sourceDataTable.addColumnMetadata("TEACHER", java.sql.Types.VARCHAR);
						sourceDataTable.addColumnMetadata("CLANO", java.sql.Types.VARCHAR);
						sourceDataTable.addColumnMetadata("SEX", java.sql.Types.CHAR);
						sourceDataTable.addColumnMetadata("NAME", java.sql.Types.VARCHAR);
						sourceDataTable.addColumnMetadata("AGE", java.sql.Types.INTEGER);
						sourceDataTable.addColumnMetadata("STUNO", java.sql.Types.INTEGER);
						
						
						// 可一次性将多个不同学生插入到同一个班级中
						for (Student student : clazz.getStudent()) {
							// 将数据添加进创建的Table表中
							sourceDataTable.addRow(clazz.getTeacher(), clazz.getClaNo(), 
													student.getSex(), student.getName(),
													student.getAge(), student.getStuNo());
						}
						
						// 字符串"clazz_Table"为调用数据库存储过程“proc_test01”中,其内部编写的临时表名称
						cs.setStructured(1, "clazz_Table", sourceDataTable);
						cs.registerOutParameter(2, java.sql.Types.INTEGER);   // 可返回值的参数
						
						return cs;
					}
				}, 
				new CallableStatementCallback() {
					@Override
					public Integer doInCallableStatement(CallableStatement cs) throws SQLException, DataAccessException {
						cs.execute();
						return cs.getInt(2);   // 将第“2”个参数的值返回。第“2”个参数,其类型是“返回值类型参数”
					}
				}
			);
		
		count = testCount;   // 将testCount变量赋值给count变量
		return count;
		
	}  // public int putClazz(Clazz clazz)
    
}


Student.java类(学生类),其代码如下

package com.entity;

public class Student {
	
	private char sex;  // 性别
	
	private String name;  // 姓名
	
	private int age;      // 年龄
	
	private int stuNo;    // 学号  
	
	
	public char getSex() {
		return sex;
	}

	public void setSex(char sex) {
		this.sex = sex;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public int getAge() {
		return age;
	}

	public void setAge(int age) {
		this.age = age;
	}

	public int getStuNo() {
		return stuNo;
	}

	public void setStuNo(int stuNo) {
		this.stuNo = stuNo;
	}
	
	
}



Clazz.java类(班级类)

package com.entity;

import java.util.List;

public class Clazz {
	
	private String teacher;   // 班主任
	
	private String claNo;     // 班级编号
	
	private List stuList;  //学生

	public String getTeacher() {
		return teacher;
	}

	public void setTeacher(String teacher) {
		this.teacher = teacher;
	}

	public String getClaNo() {
		return claNo;
	}

	public void setClaNo(String claNo) {
		this.claNo = claNo;
	}

	public List getStuList() {
		return stuList;
	}

	public void setStuList(List stuList) {
		this.stuList = stuList;
	}
	
	
	
}


--------------------------------------------------------------------------

--------------------------------------------------------------------------

例如,写一接口,调用putClazz()函数,则可传递一组JSON数据,其数据格式如下所示。通过调用putClazz()函数,可以做到在一次提交数据过程中:一个班级可以插入多个学生信息。

JSON格式代码:

{
    "teacher": "吴老师",
    "clano": "打杂1班",
    "stuList": [
        {
            "sex": "男",
            "name": "吃瓜群众",
            "age": 18,
            "stuNo": 101001
        },
        {
            "sex": "女",
            "name": "如花",
            "age": 16,
            "stuNo": 101002
        },
        {
            "sex": "女",
            "name": "龅牙珍",
            "age": 20,
            "stuNo": 101001
        }
    ]
}






本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

其实从应用层面上,Win2000的Telnet服务并没有什么可说的,绝大部分内容你都可以从HELP文件中得到,我在此只是把它稍微整理一下而已。 Win2000为我们提供了Telnet客户机和服务器程序:Telnet.ex...

关键字: Telnet Client server

前言sql优化是一个大家都比较关注的热门话题,无论你在面试,还是工作中,都很有可能会遇到。如果某天你负责的某个线上接口,出现了性能问题,需要做优化。那么你首先想到的很有可能是优化sql语句,因为它的改造成本相对于代码来说...

关键字: sql

无论是开发、测试,还是DBA,都难免会涉及到数据库的操作,比如:创建某张表,添加某个字段、添加数据、更新数据、删除数据、查询数据等等。

关键字: 数据库 sql

作者一直认为,从应用程序到框架再到系统,使用每一个代码是一回事理解。使用“今天,作者将研究服务器端套接字的功能。准确地说,它是bind(基于linux3.10)。

关键字: Linux bind server

  案例场景   某排水集团在线业务区的SCADA系统需要从DMZ区的I/O Server上采集数据,SCADA系统使用某些IP能够正常从I/O Server采集数据,但是另一部分IP则

关键字: scada server 数据包

如何选择腾讯云服务器操作系统? 腾讯云服务器操作系统通过镜像安装。 哪个最适合腾讯云镜像? 服务器选择镜像Linux系统还是Windows服务器? 云服务器栏(yunfuwuqiba.com)说明了腾讯云服务器的镜像列表...

关键字: Linux server Windows 腾讯云

前言 上一篇总结了Mysql的锁机制,通过读者的反映和阅读量显示,总体还是不错的,感兴趣的可以阅读一下[大厂面试官必问的Mysql锁机制]。 写了那么多的Mysql文章,有读者问我是不是dba,工作真的需要掌握那么深吗。...

关键字: sql

前言 前几天有粉丝和我聊到他找工作面试大厂时被问的问题,因为现在疫情期间,找工作也特别难找。他说面试的题目也比较难,都偏向于一两年的工作经验的面试题。 他说在一面的时候被问到Mysql的面试题,索引那块自己都回答比较满意...

关键字: sql

Linux 进程间通信的几种主要手段。其中管道和有名管道是最早的进程间通信机制之一,管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具有的功能外,它还允许无亲缘

关键字: Linux server

1.下载源码并解压缩 下载网址:http://www.tightvnc.com/download.php  tar xjf tightvnc-1.3.10_unixsrc.tar.bz2  cd vn

关键字: server tcp
关闭
关闭