[oracle] oracle-myibatis-整理
==================================== 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-整理的更多相关文章
- oracle常用函数整理
oracle常用函数整理 1.绝对值.取余.判断数值正负函数 绝对值:ABS(n) 示例: SELECT ABS(100),ABS(-100),ABS('100') FROM ...
- 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 ...
- 性能监控工具的配置及使用 - Spotlight On Oracle(oracle)
一. Spotlight On Oracle(oracle)1.1. 工具简介Spotlight是一个强有力的Oracle数据库实时性能诊断工具,提供了一个直观的.可视化的数据库活动展现.S ...
- 性能监控工具的配置及使用 - Spotlight On Oracle(oracle) 转:紫漪
一. Spotlight On Oracle(oracle) 1.1. 工具简介 Spotlight是一个强有力的Oracle数据库实时性能诊断工具,提供了一个直观的.可视化的数据库活动展现 ...
- ORACLE| ORACLE基础语法汇总
创 ORACLE| ORACLE基础语法汇总 2018-07-18 16:47:34 YvesHe 阅读数 9141更多 分类专栏: [数据库] 版权声明:本文为博主原创文章,遵循CC 4.0 B ...
- Oracle学习笔记整理手册
文章目录(1)Oracle正则匹配使用(2)Oracle修改有数据的数据字段类型(3)Oracle表数据回滚语句(4)sql筛选出记录数大于2的记录(5)oracle同义词(6)oracle内外连接( ...
- Oracle Hint用法整理笔记
目录 1./+ result_cache / 2./+ connect_by_filtering / 3./+ no_unnset / 4./+ index(表别名 索引名) / 5./+ INDEX ...
- 工作中用到的oracle字符串分割整理
oracle部分: 定义类型(用于字符串分割): create or replace TYPE "STR_SPLIT" IS TABLE OF VARCHAR2 (4000); 字 ...
- Oracle系统表整理+常用SQL语句收集
欢迎和大家交流技术相关问题: 邮箱: jiangxinnju@163.com 博客园地址: http://www.cnblogs.com/jiangxinnju GitHub地址: https://g ...
- oracle分区表(整理)
Oracle 表分区 早在8.0.5版本中,Oracle就将范围分区技术引入,现在分区功能已经越来越强大,包括支持扩展分区功能.Interval分区.外键分区.模拟列分区.以及分区建议器等.那么,分区 ...
随机推荐
- 转Jmeter报告优化之New XSL stylesheet
Jmeter默认的报告展示的信息比较少,如果出错了,不是很方便定位问题.由Jmeter默认报告优化这篇文章可知,其实由.jtl格式转换为.html格式的报告过程中,style文件起了很关键的作用.下面 ...
- python标准库介绍——8 operator 模块详解
==operator 模块== ``operator`` 模块为 Python 提供了一个 "功能性" 的标准操作符接口. 当使用 ``map`` 以及 ``filter`` 一类 ...
- MySQL数据分组GROUP BY 和HAVING
对于分组的理解,可以这样:对GROUP BY子句后面跟随的列名进行分组,然后对每一个分组而不是整个表进行操作. 举例如下:在产品表中,检索每一个供应商提供的商品的数量. mysql> SELEC ...
- Linux中telnet命令
telnet命令通常用来远程登录.telnet程序是基于TELNET协议的远程登录客户端程序.Telnet协议是TCP/IP协议族中的一员,是Internet远程登陆服务的标准协议和主要方式.它为用户 ...
- mysql如何查找某字段所在表
如果是5.0以上的,以root用户连接,可以看到一个叫information_schema的表, 然后只要:use information_schema; select `TABLE_NAME`fro ...
- Android开发7——android.database.CursorIndexOutOfBoundsException:Index -1 requested
android中数据库处理使用cursor时,游标不是放在为0的下标,而是放在为-1的下标处开始的. 也就是说返回给cursor查询结果时,不能够马上从cursor中提取值. 下面的代码会返回错误Us ...
- graphite的安装文档
http://www.th7.cn/Program/Python/201603/783804.shtml https://lanjingling.github.io/2016/04/04/graphi ...
- 国外程序员整理的Java资源大全
构建 这里搜集了用来构建应用程序的工具. Apache Maven:Maven使用声明进行构建并进行依赖管理,偏向于使用约定而不是配置进行构建.Maven优于Apache Ant.后者采用了一种过程化 ...
- Notes on PEP333 (Python Web Server Gateway Interface)
This note is about PEP3333- Python Web Server Gateway Interface. Refer to (Source: http://legacy.pyt ...
- XILINX XST综合的选项的含义
所谓综合,就是将HDL语言.原理图等设计输入翻译成由与.或.非门和RAM.触发器等基本逻辑单元的逻辑连接(网表),并根据目标和要求(约束条件)优化所生成的逻辑连接,生成EDF文件.完成了输入.仿真以及 ...