关于博客中使用的Guns版本问题请先阅读 Guns二次开发目录
在上一篇博客中,我们解决了【代码生成】页面的数据列表中没有数据表信息的问题,这一篇博客我们来使用guns的代码生成器快速开发商品分类模块,同样的,开始之前,还是建议大家先去观看一下 guns代码生成演示 这个视频。好了,下面开始切入正题。
1、先在数据库中生成一下数据表:
DROP TABLE IF EXISTS `mall_category`;
CREATE TABLE `mall_category` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`parent_id` int(11) NOT NULL COMMENT '父类别id,当id=0时,说明是根节点,一级类别',
`parent_ids` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '当前类别的所有父类别id,包含多层级别的父类别id,方便查找',
`name` varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '类别名称',
`status` tinyint(2) NOT NULL DEFAULT '1' COMMENT '类别状态。1,使用中;2,停用中;3,已删除',
`depth` int(11) NOT NULL DEFAULT '1' COMMENT '深度,也就是菜单层级,1表示第一级,2表示第二级,以此类推',
`sort` int(8) NOT NULL DEFAULT '0' COMMENT '排序编号,同类展示顺序,数值相等则自然排序',
`version` int(11) NOT NULL COMMENT '版本(乐观锁保留字段)',
`create_time` bigint(20) DEFAULT NULL COMMENT '创建时间。13位unix的时间戳,单位是毫秒',
`update_time` bigint(20) DEFAULT NULL COMMENT '更新时间。13位unix的时间戳,单位是毫秒',
PRIMARY KEY (`id`),
KEY `index_sort_num` (`sort`)
) ENGINE=InnoDB AUTO_INCREMENT=63 DEFAULT CHARSET=utf8;
2、在【代码生成】页面生成相应的代码
查看代码是否生成:
3、配置文件中添加实体类的包扫描路径:
4、重新运行项目
修改后再次重启:
5、数据库中运行生成的sql文件
6、配置菜单栏显示
再次刷新页面:
7、Invalid bound statement (not found)异常的解决
发现异常:“org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.baomidou.mybatisplus.mapper.BaseMapper.selectList”
网上找了很久,都没有找到直接答案,然后东绕西绕最后绕到了mybatisplus的官方文档:https://mp.baomidou.com/guide/faq.html#%E5%87%BA%E7%8E%B0-invalid-bound-statement-not-found-%E5%BC%82%E5%B8%B8,截图如下:
修改项目配置:
8、重新部署生成的代码的包存放路径
最后,我发现自己对生成的代码存放路径不是很满意,于是手动给生成的代码挪个窝,先挪动java代码:
操作步骤是:
修改配置信息:
然后是挪动生成的html页面和js页面:
最初的目录结构是这样的:
如此就好看很多了,而且以后我新增的模块生成的代码,也都统一放到这个包下,如此一来,elephish包下的代码,就彻底变成Guns以外的我个人业务的代码包了。我写这么多,只是为了证明,开源框架只要接触的足够升入,按照自己的意愿去修改代码其实也是没有问题的。也许有人会说,这样去修改文件目录是或否会增加工作量,这个就看个人的追求了,比如我的追求是尽量让项目的整体结构能规范化。
不过这样改毕竟还是有些麻烦,至于是否可以自己配置生成的文件存放的路径,因为时间问题,我目前暂无研究。等哪天有空,并且想起来了,再去研究吧。
该系列更多文章请前往 Guns二次开发目录