根据mooc 数据库旧代码 实现剥离数据库链接单独成类,并进行测试

数据源详情链接,SQLserver 2019 代码复制粘贴可产生数据 

 数据库JDBC 查询sqlserver 2019 利用模板实现输入查询-CSDN博客

效果如下

剥离的链接模块

 Slinkv2.java

package SQLadd;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Scanner;

import com.microsoft.sqlserver.jdbc.ISQLServerPreparedStatement;
import java.sql.PreparedStatement;

//对比给的BaseDao后发现每次增删查改都会进行链接,于是进行剥离,把链接部分摘出,形成Slinkv2类

public class Slinkv2 {
//	分离字符串
	
	private String drivername="com.microsoft.sqlserver.jdbc.SQLServerDriver";
	private String url="jdbc:sqlserver://localhost:1433;DatabaseName=cyz;encrypt=true;trustServerCertificate=true";
	private String userName="sa";
	private String userPassWord="sa";
	private Connection conn=null;
//	链接数据库,在每次增删查改时使用
	public Connection getConnection() {
		try {
//			通过名称获取一个类,注释掉会报错在 catch 部分的链接失败,显示没有定义要抓取的错误
			Class.forName(drivername);
//			提取conn 
//			Connection conn=DriverManager.getConnection(url);
			conn=DriverManager.getConnection(url,userName,userPassWord);
		}
		catch(ClassNotFoundException e){
//			syso +alt键+/出自动补全
			System.out.println("驱动找不到");
			e.printStackTrace();
		}
		catch(SQLException e) {
			System.out.println("数据库链接失败");
			e.printStackTrace();
		}
		return conn;
	}
//	关闭数据库链接
	public void closeAll(Connection conn,Statement stmt,ResultSet rs) {
		try {
			if(rs!=null) {
				rs.close();
			}
			if(stmt!=null) {
				stmt.close();
			}
			if(rs!=null) {
				rs.close();
			}
		}catch(Exception e) {
			System.out.println("关闭失败");
			e.printStackTrace();
		}
	}
}
//后面的是原版 slink ,在改写过程中挤到下面了
//	
//	public static void main(String[] args) {
//		
//		
		Scanner scanner=new Scanner(System.in);
		String choose = scanner.next();
		System.out.println(choose);
//		
//		try {
			Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
			Class.forName(drivername);
//			Connection con =DriverManager.getConnection("jdbc:sqlserver://localhost:1433;DatabaseName=cyz;encrypt=true;trustServerCertificate=true","sa","sa");
			System.out.println("数据库链接成功\n");
//			
//			Statement stmt = con.createStatement();
			ResultSet rs = stmt.executeQuery("use cyz SELECT bno, rbdate FROM borrow WHERE bno = 332211 ");
//			
//			
//            String sql="select * from borrow where bno=?";
//            
//            PreparedStatement pst=con.prepareStatement(sql);
//            pst.setString(1,choose);
//            ResultSet rsv2=pst.executeQuery();
//			
			? 问号被设定为参数
			String sql="SELECT bno,rbdate FROM borrow WHERE bno =?";
			设定为模板,其中(ISQLServerPreparedStatement) 是强制类型转换
            ISQLServerPreparedStatement pst=(ISQLServerPreparedStatement) con.prepareStatement(sql);
            pst.setString(1,"332211");
            第一个问号替换为字符串choose
            pst.setString(1,choose);
           执行查询
            ResultSet rsv2=pst.executeQuery();
			
//            
//            while(rsv2.next()) {
//				System.out.println(rsv2.getString("bno")+"\t"+rsv2.getString("rbdate")+"\t");
//			}
            while(rsv2.next()) {
				System.out.println(rsv2.getString("bno")+"\t"+rsv2.getString("rbdate")+"\t");
			}
//			
			while(rs.next()) {
				System.out.println(rs.getString("bno")+"\t"+rs.getString("rbdate")+"\t");
			}
//			System.out.println("读取完毕");
//			stmt.close();
//			con.close();
//		}
//		catch(ClassNotFoundException e) {
//			System.out.println("驱动找不到");
//			e.printStackTrace();
//		}catch(SQLException e) {
//			System.out.println("数据库链接不成功");
//			e.printStackTrace();
//		}
		try { 
			 //加载数据驱动
			Class.forName ("com.microsoft.sqlserver.jdbc.SQLServerDriver");
			Connection con=DriverManager.getConnection("jdbc:sqlserver://localhost:1433;DatabaseName=cyz;encrypt=true;trustServerCertificate=true","sa","sa");//库名,用户名,密码
			System.out.println("连接成功");
			
			Statement stmt = con.createStatement();// 创建SQL命令对象
			ResultSet rs = stmt.executeQuery("SELECT * FROM borrow");// 返回SQL语句查询结果集(集合)   表名
			// 循环输出每一条记录
			while (rs.next()) {
	              // 输出每个字段
	              System.out.println(rs.getString("bno") + "\t" + rs.getString("bno")+rs.getString("rbdate"));
			}
	          System.out.println("读取完毕");
	          // 关闭连接
	          stmt.close();// 关闭命令对象连接
	          con.close();// 关闭数据库连接
	          
		} catch (ClassNotFoundException e) {
			System.out.println("驱动找不到");
			e.printStackTrace();
		}catch (SQLException e) {
			System.out.println("数据库连接不成功");
			e.printStackTrace();
		}
//	}
    参考链接        
原文链接:https://blog.csdn.net/qq_46110556/article/details/116765473
//
//}

测试主函数

CheckMethod.java

package SQLadd;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Scanner;

public class CheckMethod {
	
	public static void main(String[] args) {

		
		Scanner scanner = new Scanner(System.in);
		String choose = scanner.next();
		System.out.println(choose);
		
		Slinkv2 linkmanager = new Slinkv2();
		
		Connection con = linkmanager.getConnection();
//		自动补齐的
		try {
			Statement stmt = con.createStatement();
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		String sql = "select * from borrow where bno=?";

		PreparedStatement pst = null;
		try {
			pst = con.prepareStatement(sql);
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
		try {
			pst.setString(1, choose);
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
		ResultSet rsv2 = null;
		try {
			rsv2 = pst.executeQuery();
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
		try {
			while (rsv2.next()) {
				System.out.println(rsv2.getString("bno") + "\t" + rsv2.getString("rbdate") + "\t");
			}
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		System.out.println("读取完毕");
		
//		关闭数据流动,实际是设置为 null 来标记为空
		linkmanager.closeAll(con, pst, rsv2);
		
	}
}
//		try {
			Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
			Connection con = DriverManager.getConnection(
					"jdbc:sqlserver://localhost:1433;DatabaseName=cyz;encrypt=true;trustServerCertificate=true", "sa",
					"sa");
			System.out.println("数据库链接成功\n");
			新增这一条,发现有数据检测不到exception,于是之间禁用excetion,表现为全部注释掉,重新提取,去除意外检测模块
//			Connection con = linkmanager.getConnection();
//
//			Statement stmt = con.createStatement();
			ResultSet rs = stmt.executeQuery("use cyz SELECT bno, rbdate FROM borrow WHERE bno = 332211 ");
//
//			String sql = "select * from borrow where bno=?";
//
//			PreparedStatement pst = con.prepareStatement(sql);
//			pst.setString(1, choose);
//			ResultSet rsv2 = pst.executeQuery();
//
			? 问号被设定为参数
			String sql="SELECT bno,rbdate FROM borrow WHERE bno =?";
			设定为模板,其中(ISQLServerPreparedStatement) 是强制类型转换
            ISQLServerPreparedStatement pst=(ISQLServerPreparedStatement) con.prepareStatement(sql);
            pst.setString(1,"332211");
            第一个问号替换为字符串choose
            pst.setString(1,choose);
           执行查询
            ResultSet rsv2=pst.executeQuery();
			
//
//			while (rsv2.next()) {
//				System.out.println(rsv2.getString("bno") + "\t" + rsv2.getString("rbdate") + "\t");
//			}
            while(rsv2.next()) {
				System.out.println(rsv2.getString("bno")+"\t"+rsv2.getString("rbdate")+"\t");
			}
//
			while(rs.next()) {
				System.out.println(rs.getString("bno")+"\t"+rs.getString("rbdate")+"\t");
			}
//			System.out.println("读取完毕");
			stmt.close();
			con.close();
//		} catch (ClassNotFoundException e) {
//			System.out.println("驱动找不到");
//			e.printStackTrace();
//		} catch (SQLException e) {
//			System.out.println("数据库链接不成功");
//			e.printStackTrace();
//		}
//	}
//    参考链接        
//原文链接:https://blog.csdn.net/qq_46110556/article/details/116765473

//}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/701427.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

在ensp上配置动态路由协议实验设计

动态路由协议是用来在网络中自动更新路由信息的一种技术,它可以让网络设备(如路由器)根据当前网络的状态调整数据的传输路径。这种协议特别适用于大型复杂的网络环境,可以有效地处理网络配置的变化,如链接的添加、删除…

flutter报错You are currently using Java 1.8

flutter报错Could not run phased build action using connection to Gradle distribution ‘https://services.gradle.org/distributions/gradle-7.6.3-all.zip’.\r\norg.gradle.api.ProjectConfigurationException: A problem occurred configuring root project ‘android’…

Android RelativeLayout Rtl布局下的bug:paddingStart会同时作用于左右内边距

问题现象 如上图,只是设置了paddingStart,在RTL布局下,左右都产生了10dp的间距。其他布局如LinearLayout,FrameLayout则没有这个问题。 private void positionAtEdge(View child, LayoutParams params, int myWidth) {if (isLayou…

问题:一般在管理工作复杂、面广且管理分工比较细致的单位,常采用()组织形式。 #媒体#媒体

问题:一般在管理工作复杂、面广且管理分工比较细致的单位,常采用()组织形式。 A.直线式 B.职能式 C.矩阵式 D.团队式 参考答案如图所示

使用易备数据备份软件,简单快速地备份 Oracle 数据库

易备数据备份软件能够以简单高效的方式,实现对 Oracle 数据库的保护。 易备数据备份软件数据库备份功能的关键特性 自动保护网站数据库及应用程序实时备份,不需要任何中断或数据库锁定基于日期和时间的备份任务计划可恢复到一个已存在的数据库或创建一…

Web前端大作业:基于html+css+js的仿淘宝首页前端项目(内附源码)

文章目录 一、项目介绍二、项目展示三、源码展示四、源码获取 一、项目介绍 这个项目是一个Web前端大作业,目的是让学生们通过实践仿设计淘宝官网的前端页面,来全面锻炼他们的HTML、CSS和JavaScript编程能力,以及产品需求分析、界面设计、交互设计等软实力。 淘宝作为国内最大…

TMCM-BB1是单轴板驱动器

TMCM-BB4 简介 TMCM-BB1和TMCM-BB4是Trinamic插槽式模块的基板。TMCM-BB1是单轴板,提供对一个MCU模块和一个驱动器模块的访问。TMCM-BB4是一个4轴板,提供对41模块插槽的访问。TMCM-0930模块采用单36针PCI插座,整个系统采用主MCU(…

【精品方案推荐】大数据治理平台建设解决方案(66页PPT)

随着企业数据量的迅速增长和复杂化,如何有效管理、分析和利用这些数据成为企业面临的重要挑战。大数据治理平台作为解决这一问题的关键工具,旨在为企业提供全面、高效的数据管理、安全保障和业务支持。 问题1:上大数据平台要废弃已上线的传统…

BitMEX 联合创始人 Arthur Hayes 加入 Covalent 担任战略顾问

Arthur Hayes 加入 Covalent Network(CQT),成为其战略顾问。 Hayes 认为 Covalent 与其竞争对手如 The Graph 相比,Covalent Network 的 CQT 代币一直被相对低估,他希望帮助 Covalent Network(CQT&#x…

【深度学习】数竹签演示软件系统

往期文章列表: 【YOLO深度学习系列】图像分类、物体检测、实例分割、物体追踪、姿态估计、定向边框检测演示系统【含源码】 【深度学习】物体检测/实例分割/物体追踪/姿态估计/定向边框/图像分类检测演示系统【含源码】 【深度学习】YOLOV8数据标注及模型训练方法整…

Playwright+Python+Pytest:基础方法二次封装简化及链式调用

引言 随着Web应用的日益复杂化,自动化测试成为了确保软件质量的关键环节。Playwright 是一个强大的自动化库,它支持在 Chromium、Firefox 和 WebKit 中运行自动化脚本。本文将介绍如何使用 Playwright 的 Python 同步 API 来简化点击和填充操作&#xf…

UnityAPI学习之Animator的基本使用

动画与动画控制器 示例1: 创建Animator对动画控制器进行统一管理,在Gris中创建Animator组件,并对其中的Controller属性进行赋值 在进行动画创作前,需先将图片的Texture Type属性改为Sprite(2D and UI) 再将一系列图片拖入Gris物…

【java计算机毕设】图书商城管理系统MySQL springboot vue html maven送文档

1项目功能介绍 【java计算机毕设】图书商城管理系统 Java Spring Boot vue HTML MySQL 赠送文档 PPT 2项目简介 系统功能: 图书商城管理系统包括管理员和用户两种角色。 管理员的功能包括在个人中心修改个人信息,以及在基础数据管理中管理会员等级类型和…

idea安装步骤 激活码分享2024 最新版本 ,附激活码,亲测到2099

1.下载安装IDEA 略 一步一步确定安装,然后打开 这里提示输入激活码,先关闭应用!!! 2.下载工具 打开下载好的工具(下载后记得不要删除和移动,然后安装的路径尽量不要带中文路径、删掉就会失效…

Maven认识与学习

1. Maven介绍 1.2 初识Maven 1.2.1 什么是Maven Maven是Apache旗下的一个开源项目,是一款用于管理和构建java项目的工具。 官网:Maven – Welcome to Apache Maven Apache 软件基金会,成立于1999年7月,是目前世界上最大的最受…

正大国际期货:如何培养个好心态呢?

期货市场中的心态之道 在期货市场中,每一个交易者都像是航行在波涛汹涌的大海中的舵手。市场的波动、信息的繁杂、情绪的起伏,都如同海上的风浪,不断考验着每一位舵手的意志和心态。那么,如何在这样的环境中保持一个好的心态呢&am…

DOS 命令

Dos: Disk Operating System 磁盘操作系统, 简单说一下 windows 的目录结构。 ..\ 到上一级目录 常用的dos 命令: 查看当前目录是有什么内容 dir dir d:\abc2\test200切换到其他盘下:盘符号 cd : change directory 案例演示:切换…

LeetCode题练习与总结:二叉树中的最大路径和--124

一、题目描述 二叉树中的 路径 被定义为一条节点序列,序列中每对相邻节点之间都存在一条边。同一个节点在一条路径序列中 至多出现一次 。该路径 至少包含一个 节点,且不一定经过根节点。 路径和 是路径中各节点值的总和。 给你一个二叉树的根节点 ro…

简单了解java中线程的使用

线程 1、线程的相关概念 1.1、并行和并发 并行:在同一时刻,有多个任务在多个CPU上同时执行 并发:在同一时刻,有多个任务在单个CPU上交替执行 1.2、进程和线程 进程:就是在多任务管理系统中,每个独立执…

1502 - JUC高并发

慢慢挣,今天比昨天更有钱,明天比今天有钱,后天比明天有钱。 0.思维导图 6.多线程锁 synchronized实现同步的基础:Java中的每一个对象都可以作为锁。 具体表现为以下3中形式 对于普通同步方法,锁是当前实例对象。对于…