Java 通用存储过程ORMapping的实现 [基类实现篇]

原创 2007年10月01日 22:57:00

 在[设想篇]中,ASon是继承自A,而A这个基类,我们必须实现它,将A更名成:JxDataStoreProcedure

实现代码:

import java.io.*;
import java.lang.reflect.*;

/** *//**
 * <p>Title: 存储过程类</p>
 * <p>Description: 数据库映射组件</p>
 * <p>Copyright: Copyright (c) 2007</p>
 * <p>Company: itbabysoftware</p>
 * 
@author javasuki
 * 
@version 1.0
 
*/

public class JxDataStoreProcedure implements Serializable
...{
    
private Object JxSpObject;
    
private Class JxSpClass;
    
protected JxDataStoreProcedure() throws Exception
    
...{

        
//该类为受保护,通过反射进行调用,为便于管理是放在不同的包中的
        JxSpClass = Class.forName("JXDO.Data.Factory.JxStoredProcedure");
        JxSpObject 
= RefCreateObj.getPublicObj(JxSpClass);//反射建立,如果你放在同一包中,就直接使用new 建立对象吧!

    }

    
    
/** *//**
     * 执行存储过程,如果存储过程有返回结果,则返回,否则返回null
     * 
@return 必须注意:如果存储过程,最后一条程序语句后返回值,并且最后第二条程序语句为[select * from table],则该函数执行后的返回结果是com.sun.rowset.CachedRowSetImpl类型,存储Return的返回值,将放置在指定的属性中
     * 
@throws Exception
     
*/

    
public Object Exectue() throws Exception
    
...{
        
//等同于执行,new JXDO.Data.Factory.JxStoredProcedure().Exectue(this);
        Method method = JxSpClass.getDeclaredMethod("Exectue"new Class[]...{Object.class});
        method.setAccessible(
true);
        Object objResult 
=  method.invoke(JxSpObject, new Object[]...{this});
        method.setAccessible(
false);
        
return objResult;
    }

    
    
/** *//**
     * 执行存储过程,动态映射成实例的类对象,只有满足:存储过程执行后返回的是数据集,并且该数据集结构与实际数据库中表或视图的结构相同
     * 
@param InstanceClass 映射成对象的类型,//此段代码必须注意,本人有TABLE和VIEW的ORMapping,所以提供此方法
     * 
@return Object[]
     * 
@throws Exception
     
*/

    
public Object[] ExectueToObject(Class InstanceClass) throws Exception
    
...{
        
//等同于执行,new JXDO.Data.Factory.JxStoredProcedure().ExectueToObject(InstanceClass);
        Method method = JxSpClass.getDeclaredMethod("ExectueToObject"new Class[]...{Object.class,Class.class});
        method.setAccessible(
true);
        Object objResult 
= method.invoke(JxSpObject, new Object[]...{this,InstanceClass});
        method.setAccessible(
false);
        
return (Object[])objResult;
    }

}

 

如需转载,请表明出处
anthor:zerodj@163.com/javasuki@hotmail.com

SQL 2分查找法 通用分页存储过程算法 改成.net类实现

using System;namespace CountryPark.DAL{    /**////     /// PageList 的摘要说明。    ///     public sealed ...

Oracle 数据库通用类,java调用存储过程。

package com.topcheer.file.excel; import java.sql.CallableStatement; import java.sql.Connection; imp...

字符串缓存实现的通用分页存储过程

CREATE PROC sp_PageView @tbname sysname, --要分页显示的表名 @FieldKey sysname, ...

不使用存储过程的通用分页类

  • 2006年08月24日 11:11
  • 10KB
  • 下载

使用java实现oracle存储过程

  • 2010年07月30日 00:07
  • 1.44MB
  • 下载

VC调用存储过程的通用方法(SQLServer篇)

这里讨论的是ADO调用存储过程,按MSDN的例子,一般都是下面的调用方法(节选自MSDN): HRESULT hr = S_OK;     // Define ADO object point...

存储过程通用工具类

package com.athink.utility.database; import java.sql.CallableStatement; import java.sql.Connection...

C#调用存储过程的通用类

using System; using System.Collections.Generic; using System.Text; using System.Data.SqlClient; ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Java 通用存储过程ORMapping的实现 [基类实现篇]
举报原因:
原因补充:

(最多只允许输入30个字)