欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 汽车 > 新车 > 根据mooc 数据库旧代码 实现剥离数据库链接单独成类,并进行测试

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

2024/11/30 14:40:09 来源:https://blog.csdn.net/a1309602336/article/details/139622959  浏览:    关键词:根据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");第一个问号替换为字符串choosepst.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 blocke.printStackTrace();}String sql = "select * from borrow where bno=?";PreparedStatement pst = null;try {pst = con.prepareStatement(sql);} catch (SQLException e) {// TODO Auto-generated catch blocke.printStackTrace();}try {pst.setString(1, choose);} catch (SQLException e) {// TODO Auto-generated catch blocke.printStackTrace();}ResultSet rsv2 = null;try {rsv2 = pst.executeQuery();} catch (SQLException e) {// TODO Auto-generated catch blocke.printStackTrace();}try {while (rsv2.next()) {System.out.println(rsv2.getString("bno") + "\t" + rsv2.getString("rbdate") + "\t");}} catch (SQLException e) {// TODO Auto-generated catch blocke.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");第一个问号替换为字符串choosepst.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//}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com