请大家推荐一个通用的数据库(MySQL、SQLServer、Oracle)操作类,Hibernate好象太复杂了,并且把数据库变的不象数据库了。
请大家推荐一个通用的数据库(MySQL、SQLServer、Oracle)操作类,Hibernate好象太复杂了,并且把数据库变的不象数据库了。   
 在一些产品性的开发应用中,觉得Hibernate太过复杂,不够灵活,并且不标准化,而是采用了它自己定义的HSQL,这对于产品的扩展和维护应该是不利的。   
 由于MySQL、SQLServer、Oracle在操作上会有一些不一样,比如分页机制等,是否能够做到开发上的通用?还是需要分别开发三种数据库版本的产品。
------解决方案--------------------有点难,各个数据库都有点不同的。 
 sql都有点不同的。 
 帮忙up。
------解决方案--------------------没听说哪个能行,帮顶。
------解决方案--------------------使用设计模式中的工厂模式,自己定义通用数据库操作类。 
 1、定义接口:ISqlHelper 
 2、定义不同数据库的ISqlHelper的实现,如:MsSqlSqlHelper,OracleSqlHelper 
 3、定义工厂,返回ISqlHelper的实现;   
 参考思路,恕不提供代码。
------解决方案--------------------使用Java中的反射来实现自己的通用的Dao啊
------解决方案--------------------iBatis 
 绝对简单
------解决方案--------------------其实也不复杂,书籍也多,还是容易学的
------解决方案--------------------我写了一个 不嫌烂的话 拿去就是: 
 package com.gogou.common;   
 import java.util.*; 
 import java.sql.*; 
 import javax.servlet.jsp.jstl.sql.*;   
 /** 
  * This class is a bean for executing SQL statements. It has three 
  * properties that can be set: connection, sqlValue and values. 
  * The connection and sqlValue properties must always be set before 
  * calling one of the execute methods. If the values property is 
  * set, the sqlValue property must be an SQL statement with question 
  * marks as placeholders for the value objects in the values 
  * property. 
  * 
  * erdong 
  * @version 2.0 
  */ 
 public class SQLCommandBean { 
     private Connection conn; 
     private String sqlValue; 
     private List values;   
     public SQLCommandBean() { 
         try { 
             String sDBDriver =  "com.microsoft.jdbc.sqlserver.SQLServerDriver "; 
             String sConnStr = 
                      "jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=GoGou "; 
             Class.forName(sDBDriver); 
             this.conn = DriverManager.getConnection(sConnStr,  "sa ",  " "); 
         } catch (
ClassNotFoundException ex) { 
             System.out.println( "at SQLCommandBean Class
NotFoundException "); 
         } catch (
SQLException ex) { 
             System.out.println( "at SQLCommandBean SQLException "); 
         } 
     }   
     /** 
      * Sets the Connection to use. 
      */ 
     public void setConnection(Connection conn) { 
         this.conn = conn; 
     }   
     /** 
      * @param sqlValue String 
      */ 
     public void setCon() throws ClassNotFoundException, SQLException { 
         String sDBDriver =  "com.microsoft.jdbc.sqlserver.SQLServerDriver "; 
         String sConnStr = 
                  "jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=GoGou "; 
         Class.forName(sDBDriver); 
         this.conn = DriverManager.getConnection(sConnStr,  "sa ",  " "); 
     }   
     /** 
      * Set the SQL string, possibly with question mark placeholders for 
      * values set by setValues(). 
      */ 
     public void setSqlValue(String sqlValue) { 
         this.sqlValue = sqlValue; 
     }   
     /**