#2020.02.22
#今天踩的坑。
先付一个xml配置。我觉得注释我写的也比较清楚了。
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE generatorConfiguration
PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
<!-- 指定类库地址 -->
<classPathEntry
location="C:\Users\Administrator\.m2\repository\mysql\mysql-connector-java\8.0.19\mysql-connector-java-8.0.19.jar" />
<context id="DB2Tables" targetRuntime="MyBatis3" defaultModelType="flat">
<!-- 指定自己的注释器 -->
<commentGenerator type="com.capp.demo.utils.MySQLCommentGenerator">
</commentGenerator>
<!-- <commentGenerator>
<property name="addRemarkComments" value="true"/>
</commentGenerator> -->
<!-- 数据库连接串 -->
<jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"
connectionURL="jdbc:mysql://127.0.0.1:3306/wujin?serverTimezone=Hongkong&useUnicode=true&useSSL=true&characterEncoding=utf8"
userId="root" password="654321">
<!-- 可以显示表的注释 -->
<property name="useInformationSchema" value="true" />
</jdbcConnection>
<javaTypeResolver>
<!--是否使用bigDecimal,默认false。
false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer
true,把JDBC DECIMAL 和 NUMERIC 类型解析为java.math.BigDecimal-->
<property name="forceBigDecimals" value="false"/>
<!--默认false
false,将所有 JDBC 的时间类型解析为 java.util.Date
true,将 JDBC 的时间类型按如下规则解析
DATE -> java.time.LocalDate
TIME -> java.time.LocalTime
TIMESTAMP -> java.time.LocalDateTime
TIME_WITH_TIMEZONE -> java.time.OffsetTime
TIMESTAMP_WITH_TIMEZONE -> java.time.OffsetDateTime
-->
<!--<property name="useJSR310Types" value="false"/>-->
</javaTypeResolver>
<!-- java bean的放置位置 -->
<javaModelGenerator targetPackage="com.capp.demo.po" targetProject="src/main/java">
<!-- 是否创建完之后末尾跟着schema名称。-->
<property name="enableSubPackages" value="true" />
<!-- getter方法是否要再加个trim() -->
<property name="trimStrings" value="false" />
</javaModelGenerator>
<!-- mapper xml文件的位置 -->
<sqlMapGenerator targetPackage="com.capp.demo.mapper" targetProject="src/main/java">
<property name="enableSubPackages" value="false" />
</sqlMapGenerator>
<!-- mapper的java文件位置 -->
<javaClientGenerator type="XMLMAPPER"
targetPackage="com.capp.demo.mapper" targetProject="src/main/java">
<property name="enableSubPackages" value="false" />
</javaClientGenerator>
<!-- schema为数据库名,oracle需要配置,mysql不需要配置。
tableName为对应的数据库表名
domainObjectName 是要生成的实体类名(可以不指定,默认按帕斯卡命名法将表名转换成类名)
enableXXXByExample 默认为 true, 为 true 会生成一个对应Example帮助类,帮助你进行条件查询,不想要可以设为false -->
<table schema="wujin" tableName="product" domainObjectName="Product"
enableCountByExample="false" enableUpdateByExample="false"
enableDeleteByExample="false" enableSelectByExample="true"
selectByExampleQueryId="false">
</table>
<table schema="wujin" tableName="sub_trade" domainObjectName="SubTrade"
enableCountByExample="true" enableUpdateByExample="true"
enableDeleteByExample="false" enableSelectByExample="true"
selectByExampleQueryId="false">
</table>
</context>
</generatorConfiguration>
这里:
1、mybatis generator使用的xml配置文件中,xmlmapper位置不要随意更改,最好和mapper接口文件放在一起,不然业务层调用接口方法会报错,从数据库中找不到数据。
2、吹个example的彩虹屁,单表操作真的很方便。
当除了用主键查询时,指定其他查询条件时候,可以创建对应表的example类。
比如:
SubTradeExample example = new SubTradeExample();
/// 创建好这个类之后,生成条件,再进行相应的比较。
example.createCriteria().andTidEqualTo(tid);
//并且这个Criteria(条件)可以串联。但是只能用AND!!
Criteria.andTidEqualTo(tid).andStsEqualTo(1);
可以直接OR().
(因为mysql等数据库性能等原因,尽量避免使用,因为or可能无法使用索引导致全库扫描)
example.or().andCntEqualTo(1);
或者先and再or.
example.createCriteria().andTidEqualTo(tid);
example.or(example.createCriteria().andTidEqualTo(tid));
3、自己指定comment如何生成。还能自己指定属性啥的。
<commentGenerator type="com.capp.demo.utils.MySQLCommentGenerator"></commentGenerator>
public class MySQLCommentGenerator extends EmptyCommentGenerator {
private Properties properties;
public MySQLCommentGenerator() {
properties = new Properties();
}
@Override
public void addConfigurationProperties(Properties properties) {
// 获取自定义的 properties
this.properties.putAll(properties);
}
public void addModelClassComment(TopLevelClass topLevelClass, IntrospectedTable introspectedTable) {
String author = properties.getProperty("author","wujin");
String dateFormat = properties.getProperty("dateFormat", "yyyy.MM.dd");
DateTimeFormatter formatter = DateTimeFormatter.ofPattern(dateFormat);
// 获取表注释
String remarks = introspectedTable.getRemarks();
topLevelClass.addJavaDocLine("/**");
topLevelClass.addJavaDocLine(" * " + remarks);
topLevelClass.addJavaDocLine(" *");
topLevelClass.addJavaDocLine(" * @author " + author);
topLevelClass.addJavaDocLine(" * @date " + formatter.format(LocalDateTime.now()));
topLevelClass.addJavaDocLine(" */");
}
.....
}
里面可以设置的内容很多,比如getter/setter方法、javaFile,field等都可以添加注释,大家发挥想象写就行了,这就是写个备忘。
其中:EmptyCommentGenerator 是对CommentGenerator接口的空实现,就不贴代码了。
4、git其中rebase和merge的区别。
仅个人理解:
- rebase:将不同的两分支串行在一起。自己的项目的话,最好就是这个。自己开一个分支,和master合并也最好用这个。
- merge:将不同的分支并行糅杂在一起(需要你手工比对代码)