热门标签 | 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

)



推荐阅读
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文详细介绍了 GWT 中 PopupPanel 类的 onKeyDownPreview 方法,提供了多个代码示例及应用场景,帮助开发者更好地理解和使用该方法。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 本文介绍了如何利用JavaScript或jQuery来判断网页中的文本框是否处于焦点状态,以及如何检测鼠标是否悬停在指定的HTML元素上。 ... [详细]
  • Java 类成员初始化顺序与数组创建
    本文探讨了Java中类成员的初始化顺序、静态引入、可变参数以及finalize方法的应用。通过具体的代码示例,详细解释了这些概念及其在实际编程中的使用。 ... [详细]
  • 本文详细探讨了Java中的24种设计模式及其应用,并介绍了七大面向对象设计原则。通过创建型、结构型和行为型模式的分类,帮助开发者更好地理解和应用这些模式,提升代码质量和可维护性。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 主要用了2个类来实现的,话不多说,直接看运行结果,然后在奉上源代码1.Index.javaimportjava.awt.Color;im ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • 本文详细介绍了如何使用Spring Boot进行高效开发,涵盖了配置、实例化容器以及核心注解的使用方法。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
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社区 版权所有