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");

查询结果如下;

 

posted @   wiselee/  阅读(110)  评论(0编辑  收藏  举报
编辑推荐:
· 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框架的用法!
点击右上角即可分享
微信分享提示