# mgds4j
**Repository Path**: mgang/mgds4j
## Basic Information
- **Project Name**: mgds4j
- **Description**: 梦来梦往 自己写的数据源mgds4j全称mgang datasource for java
- **Primary Language**: Java
- **License**: Not specified
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 9
- **Forks**: 0
- **Created**: 2014-11-28
- **Last Updated**: 2025-07-23
## Categories & Tags
**Categories**: database-dev
**Tags**: None
## README
mgds4j
======
梦来梦往 自己实现的数据源与连接池工具,全称 mgang datasource for java
##2015-04-23
1.升级mgds4j的日志功能,基于log4j。
只需要在mgds4j.xml中的factory节点下配置常量constant key=openLog value=true 即可。
##2014-12-1
1.生成javadoc文档,微调javadoc注释。
2.export出的mgds4j-2.1.jar包放到outjar文件夹下,方便依赖使用。
##2014-11-28
升级日志:v1.1
1. 将等待时间抽出到配置文件中,默认是2000毫秒。
升级日志:v2.0
因为考虑到数据源和连接池的概念,数据源是使用连接池技术来缓存数据库连接供外使用的工具对象。
所以,将MgDataSource.java和MgConnectionPool.java合并成一个文件MgDataSource.java.
并测试通过。
升级日志:v2.1
1. 升级配置文件properties为xml
2. 加入工厂模式,单例模式,使用反射来实现。
单例模式:
private static MgDataSource mgds = null;
private MgDataSource(){
//私有的构造函数
}
/**
* 得到MgDataSource的单例对象
* @return
*/
public static MgDataSource getInstance(){
if(null == mgds){
mgds = new MgDataSource();
}
return mgds;
}
工厂模式:
//创建工厂
MgDataSourceFactory.build();
//从工厂得到数据源
ds = MgDataSourceFactory.getMgDataSource("ds");
反射机制核心:
//通过调用static函数getInstance来得到单例对象
Class dsClass = Class.forName(clazz);
ds = (MgDataSource) dsClass.getMethod("getInstance", null).invoke(dsClass, null);
factory.put(name, ds);
//得到dataSource下的property节点
Iterator ps = dsElement.elementIterator("property");
while(ps.hasNext()){
Element propertyElement = (Element) ps.next();
String key = propertyElement.attributeValue("key");
String value = propertyElement.attributeValue("value");
String type = propertyElement.attributeValue("type");
if(type.equals("string")){
Method m = MgDataSource.class.getMethod("set"+UpperFirst(key),String.class);
m.invoke(ds, value);
}else if(type.equals("int")){
Method m = MgDataSource.class.getMethod("set"+UpperFirst(key),int.class);
m.invoke(ds, Integer.parseInt(value.trim()));
}
}
##2014-11-27
今天我本来是解决struts2参数传递有时候会出现null的问题的,但是没想在此过程中碰到了45s问题和
数据库连接connection refused的问题。然后,和这两个问题一较劲,我就来解决这边了。
还好的是,都有了一定的突破。
45s问题已在网上找到解决方法,但是我还是会在我的网易博客中来写到的。
第二个问题就是数据库的连接问题了,查了一些资料,发现可能是数据源的问题,然后我就来到了数据源
与连接池的对面。
也成功的使用了常用的数据源dbcp和c3p0这两个。
然后,我就想到了自己来写这样一个数据源,利用连接池技术。当然可能做不到像dbcp和c3p0这样的成
熟技术好用。但是,我还是会自己去实现一番,就算自己以后还是用专业的数据源,这样做了也是一种进步。
如此,mgds4j这个项目也就诞生了。
***
今天算是我完成的1.0版本。
1. 实现连接池缓存数据库连接
2. 数据源得到连接,归还连接
3. 当无可用连接,按一定的长度自动增长连接池