热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

开发笔记:使用Mybatis动态生成MySQL表

篇首语:本文由编程笔记#小编为大家整理,主要介绍了使用Mybatis动态生成MySQL表相关的知识,希望对你有一定的参考价值。

篇首语:本文由编程笔记#小编为大家整理,主要介绍了使用Mybatis动态生成MySQL表相关的知识,希望对你有一定的参考价值。






一. 首先,在数据库有一张对应的表:

在这里插入图片描述


二. controller层代码如下:

@PutMapping("/dynamicallyTable")
public AjaxResult dynamicallyTable(@RequestBody Data data){
List<Template> list &#61; templateService.DynamicallyTable(data.getSid());//此处是判断表内是否有数据,有则可以继续向下执行,无则return "false"
if (list.size()&#61;&#61;0){
return AjaxResult.success("未设置模板消息,请设置模板信息",false);
}
Project tablename &#61; (Project) templateService.creatTableName(data.getSid());
String name &#61; tablename.getYear() &#43; "_" &#43; tablename.getName() &#43; "_" &#43; tablename.getStages().getName();//这里是应需求动态拼接的表名
Map<String, String> mymap &#61; new HashMap<>(); //使用map的key,value进行存值,key:"存的是field" ,value:"存储的是type"
for (Template template : list) {
String type &#61; template.getType();
String field &#61; template.getField();
mymap.put(field, type);//遍历template中的值将其分别存储到key,value中
}
templateService.creatTemplateTable(name, mymap);//此处的name为表名
iStageService.updateByStageId(data.getSid(), name);
return AjaxResult.success("成功生成定稿表");
}

三 . Service接口及其实现类:

3.1 Service接口代码如下:

/**
* &#64;Param name : 动态生成表的表名
* &#64;Param mymap: 表的列名及类型
*/

public void creatTemplateTable(String name, Map<String, String> mymap);

3.2 Service接口实现类代码如下:

/**
* &#64;Param name : 动态生成表的表名
* &#64;Param mymap: 表的列名及类型
*/

&#64;Override
public void creatTemplateTable(String name, Map<String, String> mymap) {
templateMapper.creatTemplateTable(name,mymap);
}

四, Mapper接口及其Mapper.xml

4.1 Mapper接口:

/**
* &#64;Param name : 动态生成表的表名
* &#64;Param mymap: 表的列名及类型
*/

public void creatTemplateTable(&#64;Param("name") String name,&#64;Param("mymap") Map<String, String> mymap);

4.2 Mapper.xml:

<update id&#61;"creatTemplateTable" parameterType&#61;"map">
create table ${name} (
&#96;id&#96; int(11) NOT NULL AUTO_INCREMENT,
<foreach collection&#61;"mymap" index&#61;"key" item&#61;"value" separator&#61;",">
${key} ${value}(4000)
foreach>
,PRIMARY KEY (&#96;id&#96;)
) ENGINE&#61;InnoDB DEFAULT CHARSET&#61;utf8
update>





推荐阅读
  • 如何查询zone下的表的信息
    本文介绍了如何通过TcaplusDB知识库查询zone下的表的信息。包括请求地址、GET请求参数说明、返回参数说明等内容。通过curl方法发起请求,并提供了请求示例。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • Imtryingtofigureoutawaytogeneratetorrentfilesfromabucket,usingtheAWSSDKforGo.我正 ... [详细]
  • 本文讨论了如何在codeigniter中识别来自angularjs的请求,并提供了两种方法的代码示例。作者尝试了$this->input->is_ajax_request()和自定义函数is_ajax(),但都没有成功。最后,作者展示了一个ajax请求的示例代码。 ... [详细]
  • 网络请求模块选择——axios框架的基本使用和封装
    本文介绍了选择网络请求模块axios的原因,以及axios框架的基本使用和封装方法。包括发送并发请求的演示,全局配置的设置,创建axios实例的方法,拦截器的使用,以及如何封装和请求响应劫持等内容。 ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
author-avatar
@Cobub
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有