A.CTable开源框架Mybatis增强自动创建表更新表结构实现类似hibernate共通的增删改查-mybatis-enhance-

mybatis-enhance-actable-1.3.1.RELEASE

项目已更新既支持传统Spring项目也支持Springboot项目,同时支持tk.mybatis能够支持更强大的CUDR(为避免框架直接冲突,需自行依赖,依赖即可用),强强联合,最新文档地址A.CTable-1.3.1.RELEASE文档

不用再为mybatis无法自动创建表,不提供基本的增删改查而苦恼啦!有了A.CTable这将不再成为你苦恼的理由,而且学习简单,只要进行简单的配置,然后稍微看下源码注解就可以上手了,A.CTable使用的是jdk1.7,大家使用时注意下,jdk版本和编码格式UTF-8的问题。

继之前的两篇文章阐述,我的第一个开源项目Mybatis_BuildTable_V0.2之后

新版本的Mybatis增强自动创建表框架A.CTable应运而生,初衷是为了将一系列技术融汇贯通到一个框架中,让
大家不用为了搭框架困恼,所以之前那版Mybatis_BuildTable_V0.2项目结构复杂,让使用的小伙伴感觉很不爽,因此根据大家提出的意见,我将老项目中的代码重新提取了重构了一下,并修复了一系列bug。

后来想着要取个什么名字好呢,想来想去还是Auto Create Table——A.CTable(ps:笑哭表情)

回归正题,之前两篇文章已经对该A.CTable做了技术以及用途方面的讲解,因此我这里就不再详细描述了,直接把项目里的使用说明贴过来给大家过过眼。

A.CTable使用说明

该项目是从之前写过的一个框架中抽取出来的,本身是对Mybatis做的增强功能,为了能够使习惯了hibernate框架的开发者能够快速的入手Mybatis,我给他取名叫做 “A.CTable” 本意是自动建表的意思,A.CTable是一个基于Spring和Mybatis的Maven项目,增强了Mybatis的功能,过配置model注解的方式来创建表,修改表结构,并且实现了共通的CUDR功能提升开发效率,目前仅支持Mysql,后续可能会扩展针对其他数据库的支持。

A.CTable是采用了Spring、Mybatis技术的Maven结构,详细介绍如下:

**######### mybatis增加功能自动创建表——A.CTable版本说明################**

1. 该版本修复了修改主键同时修改其类型引起的error
2. 该版本修复了根据model创建时没有创建父类中的字段的问题(ps:目前只支持扫描一层继承)
3. 该笨笨增加了对唯一约束的支持
4. 从原有的框架中剥离出来,支持任意结构的spring+mybatis的框架使用
5. 再次声明A.CTable目前仅支持mysql数据库

使用步骤方法

1.使用该功能的项目需要依赖mybatis-enhance-actable-0.0.1-SNAPSHOT.jar
2.在你的web项目上创建个目录比如config下面创建个文件autoCreateTable.properties文件的内容如下:

mybatis.table.auto=update
mybatis.model.pack=com.sunchenbin.store.model

本系统提供三种模式:

  1. 当mybatis.table.auto=create时,系统启动后,会将所有的表删除掉,然后根据model中配置的结构重新建表,该操作会破坏原有数据。

  2. 当mybatis.table.auto=update时,系统会自动判断哪些表是新建的,哪些字段要修改类型等,哪些字段要删除,哪些字段要新增,该操作不会破坏原有数据。

  3. 当mybatis.table.auto=none时,系统不做任何处理。

  4. mybatis.model.pack这个配置是用来配置要扫描的用于创建表的对象的包名

  5. spring的配置文件中需要做如下配置:

    <context:component-scan base-package="com.gitee.sunchenbin.mybatis.actable.manager.*" />
    
    <!-- 这是mybatis-enhance-actable的功能开关配置文件,其实就是将上面第2点说的autoCreateTable.properties文件注册到spring中,以便底层的mybatis-enhance-actable的方法能够获取到-->
    <bean id="configProperties" class="org.springframework.beans.factory.config.PropertiesFactoryBean">
        <property name="locations">
            <list>
                <value>classpath*:config/autoCreateTable.properties</value>
            </list>
        </property>
    </bean>
    <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PreferencesPlaceholderConfigurer">
        <property name="properties" ref="configProperties" />
    </bean>
    
    <!-- mybatis的配置文件中需要做两项配置,因为mybatis-enhance-actable项目底层是直接依赖mybatis的规范执行sql的,因此需要将其中的mapping和dao映射到一起 -->
    1. classpath*:com/gitee/sunchenbin/mybatis/actable/mapping/*/*.xml
    2. com.gitee.sunchenbin.mybatis.actable.dao.*
    
    举例这两个配置配置的详细位置
    
    <!-- myBatis文件 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    	<property name="dataSource" ref="dataSource" />
    	<!-- 自动扫描entity目录, 省掉Configuration.xml里的手工配置 -->
    	<property name="mapperLocations">
    		<array>
              <value>classpath*:com/sunchenbin/store/mapping/*/*.xml</value>
              <value>classpath*:com/gitee/sunchenbin/mybatis/actable/mapping/*/*.xml</value>
          	</array>
    	</property>
    	<property name="typeAliasesPackage" value="com.sunchenbin.store.model.*" />
    	<!-- <property name="configLocation" value="classpath:core/mybatis-configuration.xml" /> -->
    </bean>
    
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    	<property name="basePackage" value="com.sunchenbin.store.dao.*;com.gitee.sunchenbin.mybatis.actable.dao.*" />
    	<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
    </bean>
    

代码用途讲解

  1. SysMysqlColumns.java这个对象里面配置的是mysql的数据类型,这里配置的类型越多,意味着创建
    表时能使用的类型越多

  2. LengthCount.java是一个自定义的注解,用于标记在SysMysqlColumns.java里面配置的数据类型上的,标记该类型需要设置几个长度,如datetime/varchar(1)/decimal(5,2),分别是需要设置0个1个2个

  3. Column.java也是一个自定义的注解,用于标记model中的字段上,作为创建表的依据如不标记,不会被扫描到,有几个属性用来设置字段名、字段类型、长度等属性的设置,详细请看代码上的注释

  4. Table.java也是一个自定义的注解,用于标记在model对象上,有一个属性name,用于设置该model生成表后的表名,如不设置该注解,则该model不会被扫描到

  5. 系统启动后会去自动调用SysMysqlCreateTableManagerImpl.java的createMysqlTable()方法,没错,这就是核心方法了,负责创建、删除、修改表。

共通的CUDR功能使用

  1. 使用方法很简单,大家在manager或者Controller中直接注入BaseMysqlCRUDManager调用CUDR方法传入的对象参数即可。
  2. 注意:参数对象必须是你要操作表的model对象否则会报错

Gitee代码的地址

码云地址:http://git.oschina.net/sunchenbin/mybatis-enhance

Github代码地址

代码地址:https://github.com/sunchenbin/A.CTable-Frame

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
我理解了你的问题,并且会为你提供一个基本的操作流程。不过在此先说明一点,这个操作过程并不建议在生产环境中进行,建议在测试环境中进行框架的测试。以下是一个可行的方案: 1.在SSM框架中创建一个Service层接口。 2.定义一个deleteData方法接收一个参数,用来标识需要删除哪些数据。 3.在方法中找到需要删除数据的B和C,并调用它们的删除方法将它们的数据删除。 4.遍历A中的数据,找到需要删除的数据,并传递给第3步中定义的deleteData方法进行删除。 以下是参考代码: ``` @Service public class TableService { @Autowired private BTableDao bTableDao; @Autowired private CTableDao cTableDao; @Autowired private ATableDao aTableDao; public void deleteData(String someData) { List<BTable> bTables = bTableDao.queryBySomeData(someData); // 查询B中需要删除的数据 bTables.forEach(bTable -> bTableDao.delete(bTable.getId())); // 删除B中的数据 List<CTable> cTables = cTableDao.queryBySomeData(someData); // 查询C中需要删除的数据 cTables.forEach(cTable -> cTableDao.delete(cTable.getId())); // 删除C中的数据 List<ATable> aTables = aTableDao.queryBySomeData(someData); // 查询A中需要删除的数据 aTables.forEach(aTable -> { bTableDao.deleteByAId(aTable.getId()); // 根据A中的数据删除B中的关联数据 cTableDao.deleteByAId(aTable.getId()); // 根据A中的数据删除C中的关联数据 aTableDao.delete(aTable.getId()); // 删除A中的数据 }); } } ``` 这段代码中所涉及的BTableDao, CTableDao, ATableDao分别是对应的B、C和A的数据访问层接口,这里为了简化流程只给出了删除方法的实现,实际开发中需要包含各种类型的CRUD操作。 希望这个回答能对您有所帮助,如有疑问,欢迎继续提出问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值