YMP开发框架快速上手(五)— 自动生成数据实体

可紊 提交于 2019-11-30 03:15:31

本文基于上一篇《YMP开发框架快速上手(四)— 极速开发体验》博文中创建的ymp-examples-webapp项目,介绍如果快速生成数据实体。

YMP框架的数据实体生成方式目前有两种:

  1. 直接执行实体生成器类

  2. 通过YMP框架提供的Maven扩展工具插件

准备工作

在生成实体之前,需要先将示例工程中的默认数据源和实体生成规则配置好,确认ymp-conf.properties以下内容:

  • 配置默认数据源:

      # 数据库连接字符串
      ymp.configs.persistence.jdbc.ds.default.connection_url=jdbc:mysql://localhost:3306/mydb
    
      # 数据库访问用户名
      ymp.configs.persistence.jdbc.ds.default.username=root
    
      # 数据库访问密码
      ymp.configs.persistence.jdbc.ds.default.password=
    
  • 实体生成规则:

      # 是否使用类名后缀,不使用和使用的区别如: User-->UserModel,默认为false
      #ymp.params.jdbc.use_class_suffix=
    
      # 是否采用链式调用模式,默认为false
      ymp.params.jdbc.use_chain_mode=true
    
      # 数据库名称(仅针对特定的数据库使用,如Oracle),默认为空
      #ymp.params.jdbc.db_name=
    
      # 数据库用户名称(仅针对特定的数据库使用,如Oracle),默认为空
      #ymp.params.jdbc.db_username=
    
      # 数据库表名称前缀,多个用'|'分隔,默认为空
      ymp.params.jdbc.table_prefix=ymp_
    
      # 否剔除生成的实体映射表名前缀,默认为false
      ymp.params.jdbc.remove_table_prefix=true
    
      # 预生成实体的数据表名称列表,多个用'|'分隔,默认为空表示全部生成
      ymp.params.jdbc.table_list=
    
      # 排除的数据表名称列表,在此列表内的数据表将不被生成实体,多个用'|'分隔,默认为空
      #ymp.params.jdbc.table_exclude_list=
    
      # 生成的代码文件输出路径,默认为${root}
      #ymp.params.jdbc.output_path=
    
      # 生成的代码所属包名称,默认为: packages
      ymp.params.jdbc.package_name=net.ymate.platform.examples
    

方式一:直接执行实体生成器类

步骤1:修改依赖关系

打开pom.xml文件并将下列依赖配置的注释去掉:

<dependency>
	<groupId>net.ymate.platform</groupId>
    <artifactId>ymate-platform-persistence-jdbc</artifactId>
    <version>2.0-SNAPSHOT</version>
</dependency>
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.35</version>
</dependency>
<dependency>
    <groupId>commons-dbcp</groupId>
    <artifactId>commons-dbcp</artifactId>
    <version>1.4</version>
</dependency>
<dependency>
    <groupId>org.freemarker</groupId>
    <artifactId>freemarker</artifactId>
    <version>2.3.22</version>
</dependency>

步骤2:执行实体生成器

在示例工程的根路径下执行Maven命令:

mvn compile exec:java -Dexec.mainClass="net.ymate.platform.persistence.jdbc.scaffold.EntityGenerator"

注意:在Web工程中采用方式一生成实体需要注意以下几点问题:

  1. 示例项目是Web程序,编译期间需要servlet-apijsp-api包依赖,运行时是不需要它们的(因为Web容器中已提供),由于它们的作用域被设置为provided, 当执行实体生成器时会产生找不到这两个包的编译错误,所以当你需要执行实体生成器时就将这两个包的<scope>provided</scope>配置注释掉。

  2. 基于YMP框架的Web项目,其根路径默认为WEB-INF\,而普通Java工程的根路径默认为当前项目的CLASSPATH,所以在执行实体生成器时,需要确认ymp.configs.configuration.config_home和日志相关的配置参数的正确性。

  3. 确认代码生成的文件输出路径ymp.params.jdbc.output_path参数配置的正确性。

  4. 由于代码生成器执行时依赖YMP框架(也就是说所有的模块都将会被初始化),所以需要通过ymp.excluded_modules参数屏蔽掉不需要启动的模块。

通过方式一生成实体显示有些繁琐,需要注意和调整的内容比较多,因此推荐大家使用第二种方式,采用方式二请忽略上述限制。

方式二:通过YMP框架提供的Maven扩展工具插件

步骤1:编译并安装ymate-maven-extension扩展工具

  • 下载扩展工具源码(YMP框架Maven扩展工具项目地址

      执行命令:git clone https://git.oschina.net/suninformation/ymate-maven-extension.git
    
  • 编译并安装到本地Maven仓库

      执行命令: cd ymate-maven-extension
               mvn clean install
    

步骤2:将pom.xml中添加ymate-maven-plugin插件

	<plugin>
	    <groupId>net.ymate.maven.plugins</groupId>
	    <artifactId>ymate-maven-plugin</artifactId>
	    <version>1.0-SNAPSHOT</version>
	</plugin>

步骤3:执行插件生成实体

在工程根路径下执行命令:

mvn ymate:entity

输出内容:

Picked up JAVA_TOOL_OPTIONS: -Dfile.encoding=UTF-8
[INFO] Scanning for projects...
[INFO] ......(此处省略若干字)
[INFO] --- ymate-maven-plugin:1.0-SNAPSHOT:entity (default-cli) @ ymp-examples-webapp ---
三月 25, 2016 12:25:07 上午 net.ymate.platform.core.YMP init
信息: 
__   ____  __ ____          ____  
\ \ / /  \/  |  _ \  __   _|___ \ 
 \ V /| |\/| | |_) | \ \ / / __) |
  | | | |  | |  __/   \ V / / __/ 
  |_| |_|  |_|_|       \_/ |_____|  Website: http://www.ymate.net/
三月 25, 2016 12:25:07 上午 net.ymate.platform.core.YMP init
信息: Initializing ymate-platform-core-2.0.0-GA build-20160324-2339 - debug:true
......(此处省略若干字)
信息: [show tables][][1][13ms]
Output file "/Users/suninformation/IdeaProjects/ymate-platform-examples/ymp-examples-webapp/src/main/java/net/ymate/platform/examples/model/User.java".
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 1.577s
[INFO] Finished at: Fri Mar 25 00:25:08 CST 2016
[INFO] Final Memory: 10M/163M
[INFO] ------------------------------------------------------------------------

通过插件生成的代码默认放置在src/main/java路径,当数据库表发生变化时,直接执行插件命令就可以快速更新数据实体对象,是不是很更方便呢,大家可以动手尝试一下!:p

特别提示

  • 如果使用的JDBC驱动是mysql-connector-java-6.x及以上版本时,需要配置db_namedb_username参数,否则会产生异常;

One More Thing

YMP不仅提供便捷的Web及其它Java项目的快速开发体验,也将不断提供更多丰富的项目实践经验。

感兴趣的小伙伴儿们可以加入 官方QQ群480374360,一起交流学习,帮助YMP成长!

了解更多有关YMP框架的内容,请访问官网:http://www.ymate.net/

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!