==================================== insert ==========================================
语句 <insert id="insertKjtStoreOrderInfo" parameterType="com.goldenvista.kjt.entity.mapping.KjtStoreOrderInfo">
insert into KJT_STORE_ORDER_INFO
(
ORDER_ID,
ORDER_SN,
BALANCE_PAY
)
values
(
#{orderId,jdbcType=DECIMAL},
#{orderSn,jdbcType=VARCHAR},
#{balancePay,jdbcType=DECIMAL}
)
</insert>
==================================== update ==========================================
语句 <update id="operModifyPassword" parameterType="java.util.Map">
update
kjt_store_opreator_info s
set
s.oper_password=#{newPassword}
where
s.oper_Id=#{operId}
</update>
==================================== select ========================================== 语句1 <select id="queryKjtStoreCount" parameterType="java.util.Map" resultType="java.lang.Long">
select
count(*)
FROM
KJT_STORE_INFO S
where
s.status = ''
<if test="storeNo !=null">
and S.STORE_NO = #{storeNo}
</if>
<if test="longitude != null and latitude !=null">
AND GetDistance(#{longitude},#{latitude},S.STORE_LONGITUDE,S.STORE_LATITUDE)*1000 between 0 and 5000
</if>
</select> # 自定义函数 计算经纬度距离
GetDistance(#{longitude},#{latitude},S.STORE_LONGITUDE,S.STORE_LATITUDE) create or replace
FUNCTION GetDistance(
lat1 number,
lng1 number,
lat2 number,
lng2 number)
RETURN NUMBER is
earth_padius number := 6378.137;
radLat1 number := rad(lat1);
radLat2 number := rad(lat2);
a number := radLat1 - radLat2;
b number := rad(lng1) - rad(lng2);
s number := 0;
begin
s := 2 *
Asin(Sqrt(power(sin(a / 2), 2) + cos(radLat1) * cos(radLat2) * power(sin(b / 2), 2)));
s := s * earth_padius;
s := Round(s * 10000) / 10000;
return s;
end; 语句2 <!-- 分页查询 -->
<select id="queryKjtStoreList" parameterType="java.util.Map" resultType="com.goldenvista.kjt.entity.message.KjtStoreInfoModel">
SELECT * FROM (
SELECT row_.*, rownum rownum_ FROM (
SELECT
S.STORE_ID AS storeId,
S.STORE_NAME AS storeName
FROM KJT_STORE_INFO S
WHERE s.status = ''
<if test="storeNo !=null">
and S.STORE_NO = #{storeNo}
</if>
<if test="longitude != null and latitude !=null">
AND GetDistance(#{longitude},#{latitude},S.STORE_LONGITUDE,S.STORE_LATITUDE)*1000 between 0 and 5000
</if>
<if test="longitude != null and latitude !=null">
ORDER BY GetDistance(#{longitude},#{latitude},S.STORE_LONGITUDE,S.STORE_LATITUDE)*1000 ASC
</if>
<if test="longitude == null and latitude ==null">
ORDER BY S.STORE_ID desc
</if>
<![CDATA[
) row_
WHERE rownum <=#{endRecord}
)
WHERE rownum_ >#{startRecord}
]]>
</select> 语句3 <!-- 查询推荐门店商品列表数目 -->
<select id="queryKjtStoreGoodsCount" parameterType="java.util.Map" resultType="java.lang.Long">
select count(*)
from KJT_STORE_GOODS_INFO g
where g.STORE_ID = #{storeId}
and (g.GOODS_NAME like '%' || #{keyword} || '%' or g.GOODS_SN like '%' || #{keyword} || '%')
</select> 模糊查询
g.GOODS_NAME like '%' || #{keyword} || '%' 语句4 <!-- 查询包含商品集合N的所有门店 -->
<select id="queryKjtStoreListByGoods" resultType="com.goldenvista.kjt.entity.message.KjtStoreInfoModel">
select
k.STORE_ID AS storeId,
k.STORE_NAME AS storeName
from
KJT_STORE_INFO k
where k.store_id in
(
SELECT S.STORE_ID
FROM KJT_STORE_INFO S, KJT_STORE_GOODS_INFO g
WHERE S.STORE_ID = g.STORE_ID
and S.status = ''
and g.goods_id in
<foreach item="item" index="index" collection="goodsIds" open="(" separator="," close=")">
#{item}
</foreach>
)
<if test="keyword != null">
and (k.STORE_NAME like '%' || #{keyword} || '%' or k.STORE_ADDRESS like '%' || #{keyword} || '%')
</if>
</select> 语句5 <select id="getStoreInfo" parameterType="java.util.Map" resultType="com.goldenvista.kjt.entity.message.StoreInfo">
SELECT
s.store_id as store_id,
s.oper_no as oper_Id,
o.store_name as storeNmae,
to_char(s.create_date,'yyyy-MM-dd HH24:mi:ss')
FROM
kjt_store_opreator_info s,kjt_store_info o
WHERE
s.store_id = o.store_id
and s.status='' and s.oper_no = #{name} and s.oper_password =#{password}
</select> TO_CHAR 是把日期或数字转换为字符串
TO_CHAR(number, '格式')
TO_CHAR(date,’格式’) 例如:
TO_CHAR(salary,’$99,999.99’)
TO_CHAR(newdate,’yyyy-mm-dd’) 指定字符串的长度可以使用lpad或者rpad或者substring: lpad(字段名,填充长度,填充的字符) 左填充
rpad(字段名,填充长度,填充的字符) 右填充
substr( string, start_position, [ length ] )取得字符串中指定起始位置和长度的字符串

[oracle] oracle-myibatis-整理的更多相关文章

  1. oracle常用函数整理

    oracle常用函数整理    1.绝对值.取余.判断数值正负函数    绝对值:ABS(n)        示例: SELECT ABS(100),ABS(-100),ABS('100') FROM ...

  2. install_driver(Oracle) failed: Can't load `.../DBD/Oracle/Oracle.so' for module DBD::Oracle

    Description This section is from the "Practical mod_perl " book, by Stas Bekman and Eric C ...

  3. 性能监控工具的配置及使用 - Spotlight On Oracle(oracle)

    一.    Spotlight On Oracle(oracle)1.1.   工具简介Spotlight是一个强有力的Oracle数据库实时性能诊断工具,提供了一个直观的.可视化的数据库活动展现.S ...

  4. 性能监控工具的配置及使用 - Spotlight On Oracle(oracle) 转:紫漪

    一.    Spotlight On Oracle(oracle) 1.1.   工具简介 Spotlight是一个强有力的Oracle数据库实时性能诊断工具,提供了一个直观的.可视化的数据库活动展现 ...

  5. ORACLE| ORACLE基础语法汇总

    创 ORACLE| ORACLE基础语法汇总 2018-07-18 16:47:34 YvesHe 阅读数 9141更多 分类专栏: [数据库]   版权声明:本文为博主原创文章,遵循CC 4.0 B ...

  6. Oracle学习笔记整理手册

    文章目录(1)Oracle正则匹配使用(2)Oracle修改有数据的数据字段类型(3)Oracle表数据回滚语句(4)sql筛选出记录数大于2的记录(5)oracle同义词(6)oracle内外连接( ...

  7. Oracle Hint用法整理笔记

    目录 1./+ result_cache / 2./+ connect_by_filtering / 3./+ no_unnset / 4./+ index(表别名 索引名) / 5./+ INDEX ...

  8. 工作中用到的oracle字符串分割整理

    oracle部分: 定义类型(用于字符串分割): create or replace TYPE "STR_SPLIT" IS TABLE OF VARCHAR2 (4000); 字 ...

  9. Oracle系统表整理+常用SQL语句收集

    欢迎和大家交流技术相关问题: 邮箱: jiangxinnju@163.com 博客园地址: http://www.cnblogs.com/jiangxinnju GitHub地址: https://g ...

  10. oracle分区表(整理)

    Oracle 表分区 早在8.0.5版本中,Oracle就将范围分区技术引入,现在分区功能已经越来越强大,包括支持扩展分区功能.Interval分区.外键分区.模拟列分区.以及分区建议器等.那么,分区 ...

随机推荐

  1. RHEL7虚拟机添加新网卡后,网卡无法启动

    RHEL7虚拟机添加新网卡后,网卡无法启动 1.在开启网络时,有错误提示: # systemctl restart network.service Job for network.service fa ...

  2. zabbix客户端安装和配置(windows)

    下载相应版本客户端软件 zabbix_agents_2.4.4.win.zip 安装步骤 解压 1.如果是64位系统,则把\bin\win64\下面的三个文件拷贝到c:\zabbix目录下:如果是32 ...

  3. .net利用SQLBulkCopy进行数据库之间的大批量数据传递

    SQLBulkCopy,用于数据库之间大批量的数据传递.通常用于新,旧数据库之间数据的更新.即使表结构完全不同,也可以通过字段间的对应关系,顺利的将数据导过来. 首先,SQLBulkCopy需要2个连 ...

  4. 使用SplashScreenManager控件定制程序加载页面

    需要devexpress版本在12.0及以上才支持 https://www.cnblogs.com/wuhuacong/p/6112461.html 在DevExpress程序中使用SplashScr ...

  5. mysql 行转列(存储过程)

    直接sql(自己抽离代码,无法和order by rand() 复用): select shit from( select 要累加的字段, @tt:=CONCAT(@tt,',',a.要累加的字段) ...

  6. python标准库介绍——8 operator 模块详解

    ==operator 模块== ``operator`` 模块为 Python 提供了一个 "功能性" 的标准操作符接口. 当使用 ``map`` 以及 ``filter`` 一类 ...

  7. Java:多线程,线程同步,同步锁(Lock)的使用(ReentrantLock、ReentrantReadWriteLock)

    关于线程的同步,可以使用synchronized关键字,或者是使用JDK 5中提供的java.util.concurrent.lock包中的Lock对象.本文探讨Lock对象. synchronize ...

  8. C#二叉树简易实例

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Cons ...

  9. UrlOper

    using System; using System.Text.RegularExpressions; using System.Web; using System.Collections.Speci ...

  10. Avoid strong reference cycles

    转自:http://masteringios.com/blog/2014/03/06/avoid-strong-reference-cycles/ With the introduction of A ...