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

Oracle数据库操作日志与MyBatis在Oracle中的增删改查实现详解

本文详细介绍了在Oracle数据库中使用MyBatis实现增删改查操作的方法。针对查询操作,文章解释了如何通过创建字段映射来处理数据库字段风格与Java对象之间的差异,确保查询结果能够正确映射到持久层对象。此外,还探讨了插入、更新和删除操作的具体实现及其最佳实践,帮助开发者高效地管理和操作Oracle数据库中的数据。

Mybatis增删改查之Oracle

一. 查询

普通查询(返回普通的持久层对象,由于数据库字段风格和java不同,所以建立一个map映射)

select RC_ID,

RULE_CAT1,

RULE_CAT2,

RC_OPER_TYPE,

RULE_REF,

START_EFFECT_TIME,

END_EFFECT_TIME,

BOND_CODE_1,

BOND_CODE_2,

BP_THRESHOLD,

RC_STATUS,

LAST_UPDATED_DATE

FROM RULES_CONDITION

WHERE RC_ID = #{ruleConditionId,jdbcType=NUMERIC}

带有自定义对象的查询(带了一个List)

select="getBondListByRuleConditionId">

select RC_ID,

RULE_CAT1,

RULE_CAT2,

RC_OPER_TYPE,

RULE_REF,

START_EFFECT_TIME,

END_EFFECT_TIME,

BOND_CODE_1,

BOND_CODE_2,

BP_THRESHOLD,

RC_STATUS,

LAST_UPDATED_DATE

FROM RULES_CONDITION

WHERE RULE_CAT1 = #{enumValue,jdbcType=VARCHAR}

select RB_ID,

RC_ID,

t1.BOND_CODE,

t2.SECURITY_TERM,

BID_STRATEGY_ID,

OFR_STRATEGY_ID,

t1.STATUS,

t1.LAST_UPDATED_DATE

FROM RULES_BOND t1

left join BOND_BASIS_INFO t2 on t1.BOND_CODE = t2.BOND_CODE

WHERE RC_ID = #{ruleConditionId,jdbcType=NUMERIC}

二. 新增

普通新增

insert into RULES_BOND

(RB_ID,

RC_ID,

BOND_CODE,

BID_STRATEGY_ID,

OFR_STRATEGY_ID,

STATUS,

OPERATOR_ID,

LAST_UPDATED_DATE)

values (SEQ_RULES_BOND.nextVal,

#{ruleConditionId,jdbcType=NUMERIC},

#{bondCode,jdbcType=VARCHAR},

#{bidStrategyId,jdbcType=VARCHAR},

#{ofrStrategyId,jdbcType=VARCHAR},

#{status,jdbcType=VARCHAR},

#{operatorId,jdbcType=VARCHAR},

systimestamp)

返回主键(多了一个selectkey)

SELECT SEQ_RULES_BOND.Nextval from DUAL

insert into RULES_BOND

(RB_ID,

RC_ID,

BOND_CODE,

BID_STRATEGY_ID,

OFR_STRATEGY_ID,

STATUS,

OPERATOR_ID,

LAST_UPDATED_DATE)

values (#{ruleBondId,jdbcType=NUMERIC},

#{ruleConditionId,jdbcType=NUMERIC},

#{bondCode,jdbcType=VARCHAR},

#{bidStrategyId,jdbcType=VARCHAR},

#{ofrStrategyId,jdbcType=VARCHAR},

#{status,jdbcType=VARCHAR},

#{operatorId,jdbcType=VARCHAR},

systimestamp)

批量新增

参照网上写了一下,一直报缺失表达式,原来是insert into后面 是不需要 values的;

还有就是关于Oracle返回主键List ,我在网上暂时还没找到能正确执行的例子 ,求大佬告知

insert into RULES_BOND

(RB_ID,

RC_ID,

BOND_CODE,

BID_STRATEGY_ID,

OFR_STRATEGY_ID,

STATUS,

OPERATOR_ID,

LAST_UPDATED_DATE

)

SELECT SEQ_RULES_BOND.NEXTVAL,t.*

FROM (

select

#{item.ruleConditionId,jdbcType=NUMERIC},

#{item.bondCode,jdbcType=VARCHAR},

#{item.bidStrategyId,jdbcType=VARCHAR},

#{item.ofrStrategyId,jdbcType=VARCHAR},

#{item.status,jdbcType=VARCHAR},

#{item.operatorId,jdbcType=VARCHAR},

systimestamp

from dual

) t

批量新增,存在则插入

MERGE INTO RULES_CONDITION t

USING (

select #{item.ruleConditionId,jdbcType=NUMERIC} id,

#{item.ruleCatOne,jdbcType=VARCHAR} cat1,

#{item.ruleCatTwo,jdbcType=VARCHAR} cat2,

#{item.bondCodeOne,jdbcType=VARCHAR} code1,

#{item.bondCodeTwo,jdbcType=VARCHAR} code2,

#{item.ruleOperateSymbol,jdbcType=VARCHAR} symbol,

#{item.operatorId,jdbcType=VARCHAR} u

from DUAL

) t1

ON (t.RULE_CAT1 = t1.cat1 AND t.RULE_CAT2 = t1.cat2 AND t.RC_OPER_TYPE = t1.symbol)

WHEN MATCHED THEN

UPDATE SET t.BOND_CODE_1 = t1.code1,t.BOND_CODE_2 = t1.code2,t.LAST_UPDATED_DATE = default

WHEN NOT MATCHED THEN

INSERT(RC_ID, RULE_CAT1, RULE_CAT2, RC_OPER_TYPE, RULE_REF, BOND_CODE_1, BOND_CODE_2,RC_STATUS,OPERATOR_ID,LAST_UPDATED_DATE)

VALUES (SEQ_RULES_CONDITION.nextval, t1.cat1, t1.cat2, t1.symbol, '1', t1.code1, t1.code2, '0', t1.u,default)

三. 修改

(begin,end最好还是加上,之前报错一直找不到错,加上begin,end就好了;end前后都加分号";",begin不用加)

普通修改

begin

update RULES_BOND

set

BID_STRATEGY_ID=#{bidStrategyId,jdbcType=VARCHAR},

OFR_STRATEGY_ID=#{ofrStrategyId,jdbcType=VARCHAR},

OPERATOR_ID=#{operatorId,jdbcType=VARCHAR},

STATUS=#{status,jdbcType=VARCHAR},

LAST_UPDATED_DATE=SYSTIMESTAMP

WHERE RB_ID = #{ruleBondId,jdbcType=NUMERIC};

end;

批量修改(begin,end加在 foreach的open和close处,记得加上分号)

UPDATE RULES_CONDITION

RULE_REF=#{item.ruleRef,jdbcType=VARCHAR},

START_EFFECT_TIME=#{item.effectTimeOfStart,jdbcType=VARCHAR},

END_EFFECT_TIME= #{item.effectTimeOfEnd,jdbcType=VARCHAR},

BP_THRESHOLD= #{item.bpThreshold,jdbcType=NUMERIC},

RC_STATUS= #{item.ruleStatus,jdbcType=VARCHAR},

OPERATOR_ID= #{item.operatorId,jdbcType=VARCHAR},

LAST_UPDATED_DATE=default,

WHERE RC_ID = #{item.ruleConditionId,jdbcType=INTEGER}

四. 删除

普通删除

delete

from RULES_BOND

where RB_ID = #{ruleBondId}

AND TO_TIMESTAMP(TO_CHAR(LAST_UPDATED_DATE, 'yyyy-MM-dd hh24:mi:ss'), 'yyyy-MM-dd hh24:mi:ss') = #{lastUpdateTime,jdbcType=TIMESTAMP}

批量删除

​ 1)批量执行语句

DELETE FROM RULES_BOND

WHERE RB_ID = #{item.ruleBondId} and TO_TIMESTAMP(TO_CHAR(LAST_UPDATED_DATE, 'yyyy-MM-dd hh24:mi:ss'), 'yyyy-MM-dd hh24:mi:ss') = #{item.lastUpdateTime,jdbcType=TIMESTAMP}

​ 2)综合成一条语句执行

DELETE FROM RULES_BOND

WHERE RB_ID IN (

SELECT A.RB_ID FROM (

SELECT * FROM RULES_BOND

WHERE RB_ID = #{item.ruleBondId} AND TO_TIMESTAMP(TO_CHAR(LAST_UPDATED_DATE, 'yyyy-MM-dd hh24:mi:ss'), 'yyyy-MM-dd hh24:mi:ss') = #{item.lastUpdateTime,jdbcType=TIMESTAMP}

)A

)



推荐阅读
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 高效解决应用崩溃问题!友盟新版错误分析工具全面升级
    友盟推出的最新版错误分析工具,专为移动开发者设计,提供强大的Crash收集与分析功能。该工具能够实时监控App运行状态,快速发现并修复错误,显著提升应用的稳定性和用户体验。 ... [详细]
  • andr ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
author-avatar
shadowsuyan3
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有