DocSys系统开发:问题与解决方案
需积分: 0 101 浏览量
更新于2024-08-04
收藏 282KB DOCX 举报
在"DocSys系统开发问题记录1"中,讨论了两个主要的问题领域:一是如何在MyBatis的JDBC操作中获取新记录的ID,以及如何处理在二次调用Qiao.bs.dialog时可能出现的冲突问题;二是介绍了MyBatis Generator的使用方法及其注意事项,以及在数据库设计中的数据类型映射。
首先,关于获取新记录ID的方法,在JDBC操作中,Insert、Update和Delete操作通常不会直接返回新记录的ID,因为它们关注的是受影响的行数。如果需要获取新记录ID,可以采用以下两种策略:
1. **使用Identity或Sequence**: 在数据库层面,可以利用Identity特性(自动增长ID)或序列(如Oracle的序列)来确保每次插入后返回新的ID。在MyBatis中,可以通过配置`useGeneratedKeys`属性,并设置`keyProperty`为期望存储新ID的字段,让MyBatis自动管理这些操作。
2. **查询语句返回**: 如果数据库支持,可以在插入操作后执行一个SELECT语句,获取最新插入的记录的ID。这需要在插入操作后立即执行,因为如果并发插入,可能需要锁表或依赖数据库特定的机制。
对于Qiao.bs.dialog的问题,当尝试第二次打开时,由于dialog.bs.dialog会动态加载新的页面内容和JS代码到原页面,导致了页面冲突。这是因为尽管电话框关闭时删除了页面内容,但可能由于缓存原因,之前的JS代码副本仍在内存中。解决这个问题的关键在于确保清除或正确管理页面的JS状态,避免函数冲突。
MyBatis Generator是一个自动化工具,用于生成基于数据库表结构的Java代码,如DAO(Data Access Object)、Entity(实体类)和Mapper(SQL映射)。使用时,用户需根据`docsystem.xml`配置文件调整生成的模板,但要注意以下几点:
- 脚本生成的内容会覆盖用户自定义的部分,生成后需检查并手动恢复用户更改。
- 当表结构发生变化时,使用`go.bat`脚本进行更新。生成的新内容包括从`updateByPrimaryKey`开始的部分,这部分应与旧内容区分开,并对用户自定义内容进行相应修改。
另外,文件中还提及了在使用SVNKit时遇到的问题。在本地FSFS仓库中,使用`addFile`方法进行rename、move或copy操作时,可能会出现错误。这里的代码示例显示了编辑器的操作逻辑,但具体问题可能是与仓库结构或路径处理相关的,需要进一步调试和适配。
总结来说,这份文档提供了关于数据库操作技巧、MyBatis Generator的用法以及版本控制工具在特定场景下的问题解决方法,对于开发人员理解和解决这些问题具有实际指导价值。
2022-08-08 上传
2021-12-20 上传
2020-04-08 上传
2022-08-08 上传
2022-08-08 上传
2022-08-08 上传
2021-05-11 上传
2021-04-25 上传
2022-12-28 上传
KerstinTongxi
- 粉丝: 26
- 资源: 277
最新资源
- 开源通讯录备份系统项目,易于复刻与扩展
- 探索NX二次开发:UF_DRF_ask_id_symbol_geometry函数详解
- Vuex使用教程:详细资料包解析与实践
- 汉印A300蓝牙打印机安卓App开发教程与资源
- kkFileView 4.4.0-beta版:Windows下的解压缩文件预览器
- ChatGPT对战Bard:一场AI的深度测评与比较
- 稳定版MySQL连接Java的驱动包MySQL Connector/J 5.1.38发布
- Zabbix监控系统离线安装包下载指南
- JavaScript Promise代码解析与应用
- 基于JAVA和SQL的离散数学题库管理系统开发与应用
- 竞赛项目申报系统:SpringBoot与Vue.js结合毕业设计
- JAVA+SQL打造离散数学题库管理系统:源代码与文档全览
- C#代码实现装箱与转换的详细解析
- 利用ChatGPT深入了解行业的快速方法论
- C语言链表操作实战解析与代码示例
- 大学生选修选课系统设计与实现:源码及数据库架构