<?xml version="1.0" encoding="UTF-8"?>
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
<mapper namespace="com.jilongda.applet.mapper.TStoreMapper">
|
|
<!-- 通用查询映射结果 -->
|
<resultMap id="BaseResultMap" type="com.jilongda.applet.model.TStore">
|
<id column="id" property="id" />
|
<result column="name" property="name" />
|
<result column="province" property="province" />
|
<result column="provinceCode" property="provinceCode" />
|
<result column="city" property="city" />
|
<result column="cityCode" property="cityCode" />
|
<result column="area" property="area" />
|
<result column="areaCode" property="areaCode" />
|
<result column="address" property="address" />
|
<result column="createTime" property="createTime" />
|
<result column="updateTime" property="updateTime" />
|
<result column="createBy" property="createBy" />
|
<result column="updateBy" property="updateBy" />
|
<result column="isDelete" property="isDelete" />
|
<result column="lon" property="lon" />
|
<result column="lat" property="lat" />
|
<result column="img" property="img" />
|
</resultMap>
|
|
<!-- 通用查询结果列 -->
|
<sql id="Base_Column_List">
|
id, `name`, province, provinceCode, city, cityCode, area, areaCode, address, createTime, updateTime, createBy, updateBy, isDelete, lon, lat, img
|
</sql>
|
<select id="pageList" resultType="com.jilongda.applet.vo.TStoreVO">
|
select id, `name`, province, provinceCode, city, cityCode, area, areaCode, address, createTime, updateTime,
|
createBy, updateBy, isDelete, lon, lat, img
|
<if test="query.lon != null and query.lon != '' and query.lat != null and query.lat != ''">
|
,ROUND(
|
6378.138 * 2 * ASIN(
|
SQRT(
|
POW(
|
SIN(
|
(
|
#{query.lat} * PI() / 180 - lat * PI() / 180
|
) / 2
|
),
|
2
|
) + COS(#{query.lat} * PI() / 180) * COS(lat * PI() / 180) * POW(
|
SIN(
|
(
|
#{query.lon} * PI() / 180 - lon * PI() / 180
|
) / 2
|
),
|
2
|
)
|
)
|
) * 1000
|
) AS distance
|
</if>
|
from t_store
|
where isDelete = ${@com.jilongda.common.enums.DisabledEnum@NO.getCode()}
|
and status = 1
|
ORDER BY
|
<if test="query.lon != null and query.lon != '' and query.lat != null and query.lat != ''">
|
IFNULL(distance,0),
|
</if>
|
createTime DESC
|
</select>
|
|
</mapper>
|