MySQL jfinal 生成数据_JFinal Web开发学习(四)数据库连接与自动生成model

1.新建数据库jfinal_test,user表

/*

Navicat MySQL Data Transfer

Source Server : .

Source Server Version :50547Source Host : localhost:3306Source Database : jfinal_test

Target Server Type : MYSQL

Target Server Version :50547File Encoding :65001Date:2016-10-08 18:24:33*/

SET FOREIGN_KEY_CHECKS=0;-- ----------------------------

-- Table structure for `user`

-- ----------------------------

DROP TABLE IF EXISTS `user`;CREATE TABLE `user` (

`id` bigint(20) NOT NULL AUTO_INCREMENT,`name` varchar(255) NOT NULL,`pwd` varchar(255) NOT NULL,`reg_time` varchar(255) NOT NULL,PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8;-- ----------------------------

-- Records of user

-- ----------------------------

2.在res文件夹下的SystemConfig.txt文件中写入数据库连接地址,用户名密码,以及开发者模式。

jdbcUrl = jdbc:mysql://localhost:3306/jfinal_test?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull

user=root

password=root

devMode= true

package cn.pangpython.model;

import javax.sql.DataSource;

import com.jfinal.kit.PathKit;

import com.jfinal.kit.Prop;

import com.jfinal.kit.PropKit;

import com.jfinal.plugin.activerecord.generator.Generator;

import com.jfinal.plugin.c3p0.C3p0Plugin;/**

* GeneratorDemo

* 来自JFinal官方的生成器

**/public class _JFinalGenerator {

public static DataSource getDataSource() {//加载配置文件

Prop p = PropKit.use("SystemConfig.txt");//创建c3p0连接

C3p0Plugin c3p0Plugin = new C3p0Plugin(p.get("jdbcUrl"), p.get("user"), p.get("password"));

c3p0Plugin.start();returnc3p0Plugin.getDataSource();

}

public staticvoidmain(String[] args) {//base model 所使用的包名

String baseModelPackageName = "cn.pangpython.model.base";//base model 文件保存路径

String baseModelOutputDir = PathKit.getWebRootPath() + "/../src/cn/pangpython/model/base";//model 所使用的包名 (MappingKit 默认使用的包名)

String modelPackageName = "cn.pangpython.model";//model 文件保存路径 (MappingKit 与 DataDictionary 文件默认保存路径)

String modelOutputDir = baseModelOutputDir + "/..";//创建生成器

Generator gernerator = newGenerator(getDataSource(), baseModelPackageName, baseModelOutputDir, modelPackageName, modelOutputDir);//设置数据库方言

//gernerator.setDialect(new MysqlDialect());

//添加不需要生成的表名

//gernerator.addExcludedTable("adv");

//设置是否在 Model 中生成 dao 对象

gernerator.setGenerateDaoInModel(true);//设置是否生成字典文件

gernerator.setGenerateDataDictionary(false);//设置需要被移除的表名前缀用于生成modelName。例如表名 "osc_user",移除前缀 "osc_"后生成的model名为 "User"而非 OscUser

//gernerator.setRemovedTableNamePrefixes("t_");

//生成

gernerator.generate();

}

}

4.把依赖的jar包放入WebRoot/WEB-INF/lib/下

目前的jar包

65679840295a46d6669a248a0440aa67.png

5.生成

在_JFinalGenerator.java中右击--->Run As--->Java Application运行

就能生成数据库的实体类

e1c77ffa5a7a0beec7b6305f0a5548f8.png

其中base包中的类文件不需要我们手动修改,如果数据库有变动,只需要用生成器重新生成一次就OK。

model中可以定义自己的方法,比如getAllUser返回list类型.

用Jfinal老大的话说,干净清爽,打完收枪。

: )

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值