ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

三十四、java基于jdbc操作MySQL数据库之查询方法封装

2021-11-18 22:35:25  阅读:181  来源: 互联网

标签:ps jdbc java String rsmd rs 查询方法 columnName close


java基于jdbc操作MySQL数据库之查询方法封装

代码

public class TestJDBC1 {

	private String url = "jdbc:mysql://ip:3306/数据库名?characterEncoding=utf-8&useSSL=false";
	private String user = "user";
	private String password = "password";
	
	static {
		//加载驱动类到DM集合
		try {
			Class.forName("com.mysql.jdbc.Driver");
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		}
	}
	
	//java程序与数据库建立连接
	public Connection getConnection() throws Exception {
		
		DriverManager.setLoginTimeout(5);
		return DriverManager.getConnection(url, user, password);
	}
	
	//非参数化sql通用查询
	public String noParamSqlQuery(String noParamSql) throws Exception{
		Connection con = getConnection();
		//发送sql语句
		PreparedStatement ps = con.prepareStatement(noParamSql);
		ResultSet rs = ps.executeQuery();
		ResultSetMetaData rsmd = rs.getMetaData();
		int columnCount = rsmd.getColumnCount();
		
		//指定行
		JSONArray jsonArray = new JSONArray();
		
		while (rs.next()) {
			//基于行遍历列
			JSONObject jsonObject = new JSONObject();
			
			for(int columnIndex=1;columnIndex<=columnCount;columnIndex++) {
				String columnName = rsmd.getColumnName(columnIndex);
				Object object = rs.getObject(columnName);
				jsonObject.put(columnName, object);	
			}
			jsonArray.add(jsonObject);
		}		
		//关闭连接
		rs.close();
		ps.close();
		con.close();
		
		return jsonArray.toJSONString();
	}
	
	//参数化sql-封装的方法做不到通用,都是据业务实情来写的 
	public String getAutoLogInfoById(String paramSql,AutoLog autolog) throws Exception {
		//初始化
		Connection con = getConnection();
		//发送sql语句
		PreparedStatement ps = con.prepareStatement(paramSql);
		ps.setInt(1, autolog.getId());
		
		ResultSet rs = ps.executeQuery();
		ResultSetMetaData rsmd = rs.getMetaData();
		int columnCount = rsmd.getColumnCount();
		
		//指定行
		JSONArray jsonArray = new JSONArray();
		
		while (rs.next()) {
			//基于行遍历列
			JSONObject jsonObject = new JSONObject();
			
			for(int columnIndex=1;columnIndex<=columnCount;columnIndex++) {
				String columnName = rsmd.getColumnName(columnIndex);
				Object object = rs.getObject(columnName);
				jsonObject.put(columnName, object);	
			}
			jsonArray.add(jsonObject);
		}		
		//关闭连接
		rs.close();
		ps.close();
		con.close();
		
		return jsonArray.toJSONString();
	}
}

标签:ps,jdbc,java,String,rsmd,rs,查询方法,columnName,close
来源: https://blog.csdn.net/weixin_48726433/article/details/121411847

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有