相当头疼,郁闷。
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可以直接转换啊。
分享到:
相关推荐
SnapORM SnapORM 是一个非常简单的基于 JDBC 的 ORM,它提供结果集映射和基本的 crud 操作。 要将 SnapORM 作为依赖项添加到您的项目: <dependency> <groupId>...
NULL 博文链接:https://yongboy.iteye.com/blog/549243
spring-jdbc-orm基于spring-jdbc 写的一个小型ORM设计初衷由于公司现有的代码工程经历了无数人的手,原来的初衷已经变了模样,可以说乱的让我不能接受,代码中大部分都使用了Map封装实体信息,有伤大雅,大部分业务...
Jrom开发实例 Jrom JDBC ORM
pring对JDBC和orm的支持共10页.pdf.zip
mysql知识点,希望可以帮助大家 mysql知识点,希望可以帮助大家
主要介绍了spring对JDBC和orm的支持实例详解,需要的朋友可以参考下
J2EE JDBC ORM hibernate EJB Spring 实例哦,谢谢大家下载,我讲继续把我的资源共享
JDBC ORM框架灵活使用的还是JDBC,此处先简要进行下JDBC常用API的介绍和简单封装1.1 jdbc连接数据库步骤加载驱动获取连接获取声明执行SQL&渲染结果集关闭声明和关闭连接try { // 加载驱动 Class . forName( " ...
jdbcToOrm 无聊在家,用springBoot写一个orm,自动建立实体类的玩具项目突然公司研发就解散了感觉无事可做,写个orm吧,初级程序员都写烂了估计不过,打发下时间,慢慢添加一些也许会高大上的东西
Java-JDBC【之】实现ORM,结果集映射实体类(ResultSet、注解、反射) 1.ORM实现思路 2.@Table、@Column、标识实体类 2.1.创建注解 @Table、@Column 2.2.标识实体类 2.3.数据库表 3.结果集解析,注解加反射填充实体...
这是一个基于 Spring JdbcTemplate 的小工具,帮助开发者简单地完成 Mysql 的增删改查。 使用 nimble-orm 的优势 为互联网频繁的表变动而生。 表名、字段名
本项目为一个简单的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.
sql-q 一个简单的、轻量级的 Java JDBC ORM,尽可能类似于普通的 SQL,适用于 RESTful 服务。 不支持连接,但您始终可以对它们使用普通的 SQL 查询。用法模型类: public class Item {// By default, id is primary ...
大二的时候为了做个后台方便写的ORM组件 没有Hibernate那么多功能,也没有Hibernate那么多麻烦事情. 压缩包里面文档和源码还有打包的jar都奉上 呵呵 有人用就用 随便改 欢迎和我讨论技术 qq:48579466 做个广告哈
SBORM只是针对spring jdbc的一些不方便的地方,做了一些封装,更加简化日常的开发工作,基于spring jdbc的RowMapper自动实现对象映射,也勉强算的上叫ORM,只是大部分功能已经由spring jdbc实现了。 平时不太...
数据库连接池封装和ORM框架封装 涉及到知识点:多种设计模式、注解、反射.通过该封装学习,可以加深对java基础的理解
spring jdbc示例代码,包括增删改查等一系列操作。了解spring jdbc与jdbc、orm框架的区别