JDBC-对任意表进行查询操作
package JDBCTest.PrepardStamentQuery;
import JDBCTest.JDBCUtils.JDBCUtils;
import JDBCTest.PreparedStatement.Customer;
import com.mysql.jdbc.Connection;
import java.lang.reflect.Field;
import java.sql.*;
public class Test {
@org.junit.jupiter.api.Test
public void test(){
String sql = "SELECT id,NAME,email FROM customers WHERE id = ?";
Customer instance = Test.getInstance(Customer.class, sql, 2);
System.out.println(instance);
String sql1 = "SELECT id,name,date FROM `order` WHERE id= ?";
Order instance1 = Test.getInstance(Order.class, sql1, 1);
System.out.println(instance1);
}
public static <T> T getInstance(Class<T> clazz,String sql, Object ...args) {
Connection connection = null;
PreparedStatement preparedStatement = null;
ResultSet resultSet = null;
try {
connection = JDBCUtils.getConnection();
preparedStatement = connection.prepareStatement(sql);
for (int i = 0; i < args.length; i++) {
preparedStatement.setObject(i+1,args[i]);
}
resultSet = preparedStatement.executeQuery();
ResultSetMetaData metaData = resultSet.getMetaData();
int columnCount = metaData.getColumnCount();
if (resultSet.next()){
T t = clazz.newInstance();
for (int i = 0; i <columnCount ; i++) {
Object obj = resultSet.getObject(i+1);
String catalogName = metaData.getColumnName(i+1);
Field declaredField = clazz.getDeclaredField(catalogName);
declaredField.setAccessible(true);
declaredField.set(t,obj);
}
return t;
}
} catch (Exception e) {
e.printStackTrace();
} finally {
JDBCUtils.closeRuscre(connection, (com.mysql.jdbc.PreparedStatement) preparedStatement,resultSet);
}
return null;
}
}
数据库表格如下:
create table order(
id int(10) primary key AUTO_INCREMENT,
name varchar(20),
date date
);
insert into table order(name,date)
values("aa","2000-01-02"),
("bb","2020-02-02");
查询结果如下;
本文来自博客园,作者:wiselee/,转载请注明原文链接:https://www.cnblogs.com/wiseleer/articles/15942216.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!