`
qjbagu
  • 浏览: 23234 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论
  • wjl1174: String 不是基本的类型,所有他的变量就是一个对象,放在m ...
    静态字段问题
  • laojiang: 数据库设置缺省值或者类修改成Integer原因null是没办法 ...
    JDBC ORM
  • yin_bp: 补充说明一下连接池的配置     bboss persiste ...
    JDBC 批处理
  • yin_bp: 再贴点稍微有点点技术含量的,呵呵 看看开源j2ee 框架bbo ...
    JDBC 批处理
  • yin_bp: 贴点稍微有点点技术含量的,呵呵 有空看看开源bbossgrou ...
    JDBC 批处理

JDBC ORM

    博客分类:
  • JDBC
阅读更多
相当头疼,郁闷。
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可以直接转换啊。
1
3
分享到:
评论
1 楼 laojiang 2010-05-17  
数据库设置缺省值


或者类修改成Integer


原因null是没办法赋值给int的

相关推荐

    分享一个很轻的、纯JDBC ORM映射小框架,泛型化,SQL级别

    标题中的“轻量级、纯JDBC ORM映射小框架”指的是一个小型的Java库,它实现了对象关系映射(ORM)的功能,但不依赖于像Hibernate或MyBatis这样的大型框架,而是直接使用JDBC进行数据库操作。ORM是将数据库表结构映射...

    SnapORM:非常简单的JDBC ORM

    SnapORM SnapORM 是一个非常简单的基于 JDBC 的 ORM,它提供结果集映射和基本的 crud 操作。 要将 SnapORM 作为依赖项添加到您的项目: &lt;dependency&gt; &lt;groupId&gt;...

    spring-jdbc-orm:基于spring-jdbc 写的一个小型ORM

    spring-jdbc-orm基于spring-jdbc 写的一个小型ORM设计初衷由于公司现有的代码工程经历了无数人的手,原来的初衷已经变了模样,可以说乱的让我不能接受,代码中大部分都使用了Map封装实体信息,有伤大雅,大部分业务...

    pring对JDBC和orm的支持共10页.pdf.zip

    标题中的"Spring对JDBC和ORM的支持"是一个关键主题,涉及到Spring框架在数据库操作方面的核心功能。Spring是一个广泛使用的Java企业级应用开发框架,它提供了一整套工具和功能来简化JDBC(Java Database ...

    基于Java语言的ThinkJD开源JDBC/ORM操作库设计源码

    该项目是基于Java语言的ThinkJD开源JDBC/ORM操作库设计源码,共包含28个文件,涵盖11个JAR包、6个Java源文件、3个Markdown文件、3个属性文件以及其他类型文件。ThinkJD(又名ThinkJDBC)是一款功能强大的数据库操作...

    Jrom开发实例

    【Jrom开发实例】是关于使用Jrom框架进行数据库操作的一个实践教程,主要涉及的是Jrom与JDBC ORM(对象关系映射)的结合应用。ORM技术是将数据库中的数据与程序中的对象进行关联,使得开发者可以使用面向对象的方式...

    ORM-FRAMEWORK:orm框架一步一步封装(MyBatis源码学习)

    JDBC ORM框架灵活使用的还是JDBC,此处先简要进行下JDBC常用API的介绍和简单封装1.1 jdbc连接数据库步骤加载驱动获取连接获取声明执行SQL&渲染结果集关闭声明和关闭连接try { // 加载驱动 Class . forName( " ...

    一个灵活轻量级的基于SpringjdbcTemplate的ORM

    在IT行业中,ORM(Object-Relational Mapping)框架是连接数据库和应用程序的重要桥梁,它使得开发者可以使用面向对象的方式来操作数据库,而无需关心底层SQL语句的编写。Spring JdbcTemplate是Spring框架提供的一种轻...

    02-01-11-基于Spring JDBC手写定制自己的ORM框架1

    在本课程"02-01-11-基于Spring JDBC手写定制自己的ORM框架1"中,我们将探讨如何利用Spring的JdbcTemplate设计理念,来构建一个自定义的ORM(对象关系映射)框架。ORM框架的主要目的是简化Java应用程序与数据库之间的...

    jdbcToOrm:无聊在家,用springBoot写个orm,自动建实体类的玩具项目

    jdbcToOrm 无聊在家,用springBoot写一个orm,自动建立实体类的玩具项目突然公司研发就解散了感觉无事可做,写个orm吧,初级程序员都写烂了估计不过,打发下时间,慢慢添加一些也许会高大上的东西

    jdbc连接池封装及ORM框架jdbc.rar

    在这个“jdbc连接池封装及ORM框架jdbc.rar”文件中,我们可以探讨几个核心概念和技术,包括设计模式的应用、注解的使用以及反射机制。 首先,**设计模式**在软件开发中起着至关重要的作用。例如,工厂模式可能被...

    K-ORM 自定义ORM工具

    本文将详细探讨一个名为“K-ORM”的自定义ORM工具,该工具基于JDBC和Java反射机制实现,旨在提供简单易用的数据操作接口。 首先,我们要理解JDBC(Java Database Connectivity)在其中的角色。JDBC是Java平台上的...

    Java-JDBC【源码】实现ORM,结果集映射实体类(ResultSet、注解、反射)

    Java-JDBC【之】实现ORM,结果集映射实体类(ResultSet、注解、反射) 1.ORM实现思路 2.@Table、@Column、标识实体类 2.1.创建注解 @Table、@Column 2.2.标识实体类 2.3.数据库表 3.结果集解析,注解加反射填充实体...

    MySQL数据库在idea中的增删改查,JDBC简化,JDBC工具类封装,orm模式,数据库三层架构,JDBC事务

    本项目为一个简单的JDBC项目,包括:MySQL数据库在idea中的增删改查,JDBC简化,JDBC工具类封装,orm模式,数据库三层架构,JDBC事务 新建一个ProductManager的项目,实现利用ORM思想和三层架构以下功能: t_product...

    dynamic dao

    Dynamic Dao is JDBC ORM framework. It allows to use annotations to attach SQL execution to interface methods.

    基于SpringJDBC的轻量级ORM框架sborm.zip

    SBORM只是针对spring jdbc的一些不方便的地方,做了一些封装,更加简化日常的开发工作,基于spring jdbc的RowMapper自动实现对象映射,也勉强算的上叫ORM,只是大部分功能已经由spring jdbc实现了。 平时不太...

    Spring Data JDBC与JDBC的区别

    3. **ORM支持**: 尽管不如JPA(Java Persistence API)强大,但Spring Data JDBC仍然提供了对象关系映射的能力,将Java对象与数据库表关联。 4. **简化事务管理**: Spring的事务管理器使得事务控制变得简单,无需...

Global site tag (gtag.js) - Google Analytics