相当头疼,郁闷。
SQL> desc person;
名称 是否为空? 类型
----------------------------------------- -------- ---------------
ID NOT NULL NUMBER
NAME VARCHAR2(20)
BIRTHDAY DATE
MONEY NUMBER
这是person的表结构。
我想利用JDBC进行ORM测试,User类如下:
import java.sql.Date;
public class User {
private int id;
private String name;
private Date birthday;
private int money;
public User() {
}
@Override
public String toString() {
return "id=" + this.id + " name=" + this.name + " birthday="
+ this.birthday + " money=" + this.money;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Date getBirthday() {
return birthday;
}
public void setBirthday(Date birthday) {
this.birthday = birthday;
}
public int getMoney() {
return money;
}
public void setMoney(int money) {
this.money = money;
}
}
ORMTest表如下:
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
public class ORMTest {
public static void main(String[] args) throws Exception {
User user = (User)getObject("select id,name,birthday,money from person where id = 3",User.class);
System.out.println(user);
Bean bean = (Bean)getObject("select id,name,birthday,money from person where id = 3",Bean.class);
System.out.println(bean);
}
static Object getObject(String sql,Class clazz) throws InvocationTargetException,IllegalArgumentException, Exception {
Connection con = null;
PreparedStatement ps = null;
ResultSet rs = null;
try {
con = JdbcUtil.getConnection();
ps = con.prepareStatement(sql);
rs = ps.executeQuery();
ResultSetMetaData rsmd = rs.getMetaData();
int count = rsmd.getColumnCount();
String[] colNames = new String[count];
for (int i = 0; i < count; i++) {
String str = rsmd.getColumnName(i + 1);
str = str.substring(0, 1) + str.toLowerCase().substring(1);
colNames[i] = str;
}
Object object = null;
Method[] method = clazz.getMethods();
if (rs.next()) {
object = clazz.newInstance();
for (int i = 1; i <= colNames.length; i++) {
String colName = colNames[i - 1];
String methodName = "set" + colName;
for (Method m : method) {
if (methodName.equals(m.getName())) {
m.invoke(object, rs.getObject(colName));
}
}
}
}
return object;
} finally {
JdbcUtil.close(rs, ps, con);
}
}
}
为什么总是提醒IllegalArgumentException,说是参数类型不匹配。如果我把User类中的int类型的 id和money改成Object类型就可以得到结果,为什么Date和String可以直接转换啊。
分享到:
相关推荐
标题中的“轻量级、纯JDBC ORM映射小框架”指的是一个小型的Java库,它实现了对象关系映射(ORM)的功能,但不依赖于像Hibernate或MyBatis这样的大型框架,而是直接使用JDBC进行数据库操作。ORM是将数据库表结构映射...
SnapORM SnapORM 是一个非常简单的基于 JDBC 的 ORM,它提供结果集映射和基本的 crud 操作。 要将 SnapORM 作为依赖项添加到您的项目: <dependency> <groupId>...
spring-jdbc-orm基于spring-jdbc 写的一个小型ORM设计初衷由于公司现有的代码工程经历了无数人的手,原来的初衷已经变了模样,可以说乱的让我不能接受,代码中大部分都使用了Map封装实体信息,有伤大雅,大部分业务...
标题中的"Spring对JDBC和ORM的支持"是一个关键主题,涉及到Spring框架在数据库操作方面的核心功能。Spring是一个广泛使用的Java企业级应用开发框架,它提供了一整套工具和功能来简化JDBC(Java Database ...
该项目是基于Java语言的ThinkJD开源JDBC/ORM操作库设计源码,共包含28个文件,涵盖11个JAR包、6个Java源文件、3个Markdown文件、3个属性文件以及其他类型文件。ThinkJD(又名ThinkJDBC)是一款功能强大的数据库操作...
【Jrom开发实例】是关于使用Jrom框架进行数据库操作的一个实践教程,主要涉及的是Jrom与JDBC ORM(对象关系映射)的结合应用。ORM技术是将数据库中的数据与程序中的对象进行关联,使得开发者可以使用面向对象的方式...
JDBC ORM框架灵活使用的还是JDBC,此处先简要进行下JDBC常用API的介绍和简单封装1.1 jdbc连接数据库步骤加载驱动获取连接获取声明执行SQL&渲染结果集关闭声明和关闭连接try { // 加载驱动 Class . forName( " ...
在IT行业中,ORM(Object-Relational Mapping)框架是连接数据库和应用程序的重要桥梁,它使得开发者可以使用面向对象的方式来操作数据库,而无需关心底层SQL语句的编写。Spring JdbcTemplate是Spring框架提供的一种轻...
在本课程"02-01-11-基于Spring JDBC手写定制自己的ORM框架1"中,我们将探讨如何利用Spring的JdbcTemplate设计理念,来构建一个自定义的ORM(对象关系映射)框架。ORM框架的主要目的是简化Java应用程序与数据库之间的...
jdbcToOrm 无聊在家,用springBoot写一个orm,自动建立实体类的玩具项目突然公司研发就解散了感觉无事可做,写个orm吧,初级程序员都写烂了估计不过,打发下时间,慢慢添加一些也许会高大上的东西
在这个“jdbc连接池封装及ORM框架jdbc.rar”文件中,我们可以探讨几个核心概念和技术,包括设计模式的应用、注解的使用以及反射机制。 首先,**设计模式**在软件开发中起着至关重要的作用。例如,工厂模式可能被...
本文将详细探讨一个名为“K-ORM”的自定义ORM工具,该工具基于JDBC和Java反射机制实现,旨在提供简单易用的数据操作接口。 首先,我们要理解JDBC(Java Database Connectivity)在其中的角色。JDBC是Java平台上的...
Java-JDBC【之】实现ORM,结果集映射实体类(ResultSet、注解、反射) 1.ORM实现思路 2.@Table、@Column、标识实体类 2.1.创建注解 @Table、@Column 2.2.标识实体类 2.3.数据库表 3.结果集解析,注解加反射填充实体...
本项目为一个简单的JDBC项目,包括:MySQL数据库在idea中的增删改查,JDBC简化,JDBC工具类封装,orm模式,数据库三层架构,JDBC事务 新建一个ProductManager的项目,实现利用ORM思想和三层架构以下功能: t_product...
Dynamic Dao is JDBC ORM framework. It allows to use annotations to attach SQL execution to interface methods.
SBORM只是针对spring jdbc的一些不方便的地方,做了一些封装,更加简化日常的开发工作,基于spring jdbc的RowMapper自动实现对象映射,也勉强算的上叫ORM,只是大部分功能已经由spring jdbc实现了。 平时不太...
3. **ORM支持**: 尽管不如JPA(Java Persistence API)强大,但Spring Data JDBC仍然提供了对象关系映射的能力,将Java对象与数据库表关联。 4. **简化事务管理**: Spring的事务管理器使得事务控制变得简单,无需...