项目介绍
项目比较简单,所有和分库相关的都在shardingcore中。 test是测试用的。
shardingcore的项目结构。
其中MultipleDataSource是为了实现切换数据库连接,这块代码是参考网上数据库读写分离的。
ShardingDBAspect是分库的核心代码。
使用shardingcore
我们假设要对user进行分库,分3个库
下面是test工程,比较简单就是操作数据库。
这里重点看一下UserDao,如果你想在项目中用到分库,只需要引入shardingcore,对于dao层的需要分库的方法,比如addUser方法,需要有两个地方需要修改,一个是通过@Sharding来标示出分库的基本信息。 ,第二个通过@ShardingKey来标示出要根据哪个参数来分库。其他的代码都不需要动。
最后要对配置文件做一些修改。
<!-- aop配置,主要是拦截dao层的方法 --> <aop:config> <aop:pointcut expression="execution(public * com.sharpframework.test.repository.*Dao.*(..)) and @annotation(com.sharpframework.shardingcore.shardingannotation.Sharding)" id="shardingpoint"/> <aop:aspect id="adviceRespect" ref="sharding" order="1"> <aop:before pointcut-ref="shardingpoint" method="shardingDB"/> <aop:after pointcut-ref="shardingpoint" method="cleanshardingDB"/> </aop:aspect> </aop:config> <bean id="sharding" class="com.sharpframework.shardingcore.ShardingDBAspect"></bean> <!-- 因为会有多个数据库连接,所有会有一个抽象连接 配置可以从外部文件读取--> <bean id="db" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close" abstract="true"> <!-- 初始化连接大小 --> <property name="initialSize" value="${initialSize}"></property> <!-- 连接池最大数量 --> <property name="maxActive" value="${maxActive}"></property> <!-- 连接池最大空闲 --> <property name="maxIdle" value="${maxIdle}"></property> <!-- 连接池最小空闲 --> <property name="minIdle" value="${minIdle}"></property> <!-- 获取连接最大等待时间 --> <property name="maxWait" value="${maxWait}"></property> <property name="minEvictableIdleTimeMillis" value="60000"></property> <property name="testWhileIdle" value="true"></property> <property name="timeBetweenEvictionRunsMillis" value="45000"></property> <property name="validationQuery" value="select 'x'"></property> <property name="testOnBorrow" value="false"></property> <property name="defaultAutoCommit" value="false"></property> </bean> <!-- 数据库连接 --> <bean id="db-0" parent="db"> <property name="driverClassName" value="${user.db0.driver}"/> <property name="url" value="${user.db0.url}"/> <property name="username" value="${user.db0.username}"/> <property name="password" value="${user.db0.password}"/> </bean> <!-- 数据库连接 --> <bean id="db-1" parent="db"> <property name="driverClassName" value="${user.db1.driver}"/> <property name="url" value="${user.db1.url}"/> <property name="username" value="${user.db1.username}"/> <property name="password" value="${user.db1.password}"/> </bean> <!-- 数据库连接 --> <bean id="db-2" parent="db"> <property name="driverClassName" value="${user.db2.driver}"/> <property name="url" value="${user.db2.url}"/> <property name="username" value="${user.db2.username}"/> <property name="password" value="${user.db2.password}"/> </bean> <!-- 多数据源,注入到sqlSesionFactory,注意targetDataSources中key的名称,这里和@Sharding中dataSource 有关联 --> <bean id="multipleDataSource" class="com.sharpframework.shardingcore.multippledb.MultipleDataSource" primary="true"> <property name="defaultTargetDataSource" ref="db-0"/> <property name="targetDataSources"> <map> <entry key="db-0" value-ref="db-0"/> <entry key="db-1" value-ref="db-1"/> <entry key="db-2" value-ref="db-2"/> </map> </property> </bean>
下面是测试代码。
操作结果:
本文转自xsster51CTO博客,原文链接:http://blog.51cto.com/12945177/1950834 ,如需转载请自行联系原作者