mysql查询如何去掉多余零

 更新时间:2024年01月11日 15:49:29   作者:拿命搏未〃来  
这篇文章主要介绍了mysql查询如何去掉多余零问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

mysql查询去掉多余零

mysql 查询decimal去掉多余零 0+cast(field as char)

thinkphp指定查询字段方法增加$format参数

/**
     * 指定查询字段
     * @access public
     * @param mixed $field 字段信息
     * @param mixed $format 需要去掉多余0的 decimal字段
     * @return $this
     */
    public function field($field,$format=null)
    {
        if (empty($field)) {
            return $this;
        } elseif ($field instanceof Raw) {
            $this->options['field'][] = $field;
            return $this;
        }

        if (is_string($field)) {
            if (preg_match('/[\<\'\"\(]/', $field)) {
                return $this->fieldRaw($field);
            }

            $field = array_map('trim', explode(',', $field));
        }

        if (true === $field) {
            // 获取全部字段
            $fields = $this->getTableFields();
            $field  = $fields ?: ['*'];
        }

        if (isset($this->options['field'])) {
            $field = array_merge((array) $this->options['field'], $field);
        }
        if ($format) {
            $castField = [];
            if(is_string($format)) $format = explode(',',$format);
            if(is_array($format)){
                foreach($format as $v){
                    $asField = str_replace(".","_",$v);
                    $castField[] = '0+cast('.$v.' as char) AS '.$asField;
                }
            }
            $field = array_merge($field,$castField);
        }
        $this->options['field'] = array_unique($field);
        return $this;
    }

mysql查询常见问题

一、先排序后分组

1、MySQL版本5.6

首先order by然后group by

SELECT
    id,
    chat_id,
    content,
    create_time 
FROM
    ( SELECT id, chat_id, content, create_time FROM im_chat_message ORDER BY create_time DESC ) a 
GROUP BY
    chat_id 
ORDER BY
    create_time DESC

2、MySQL版本5.7

MySQL5.7对子查询进行了优化,认为子查询中的order by可以进行忽略,只要Derived table里不包含如下条件就可以进行优化:UNION clause、GROUP BY、DISTINCT、Aggregation、LIMIT or OFFSET

SELECT
    id,
    chat_id,
    content,
    create_time 
FROM
    ( SELECT id, chat_id, content, create_time FROM im_chat_message ORDER BY create_time DESC LIMIT 999999999 ) a 
GROUP BY
    chat_id 
ORDER BY
    create_time DESC

3、MySQL版本>=8.0

采用

ROW_NUMBER() over ( PARTITION BY chat_id ORDER BY create_time DESC )
SELECT
    id,
    chat_id,
    content,
    create_time 
FROM
    (
    SELECT
        id,
        chat_id,
        content,
        create_time,
        ROW_NUMBER() over ( PARTITION BY chat_id ORDER BY create_time DESC ) AS rn 
    FROM
        im_chat_message 
    ORDER BY
        create_time DESC 
    ) a 
WHERE
    rn =1

二、order by limit导致分页出现重复数据

从 MySQL 5.6 版本开始,优化器在使用 order by limit 时做了优化,导致排序字段没有使用索引时使用堆排序。

堆排序是不稳定的,多次排序后,各个数的相对位置发生了变化。

解决措施有两种方式:

1、排序字段加上索引。

2、在 order by 排序字段里,添加有索引的字段,比如主键ID。在排序时可以保证顺序稳定。

三、新增数据导致分页出现重复数据

新增数据导致数据总量发生了变化。

解决措施如下:

查询出当页数据后,记录本次拉取位置。

下次请求时,将上次获取的拉取位置传给后端,后端从该拉取位置开始分页。

 WHERE
   1 =1
   <if test="null != query.minId">
      and id &lt; #{query.minId}
   </if>
 LIMIT #{query.size}

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL UPDATE多表关联更新的实现示例

    MySQL UPDATE多表关联更新的实现示例

    MySQL可以基于多表查询更新数据,本文主要介绍了MySQL UPDATE多表关联更新的实现示例,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-08-08
  • 查看连接mysql的IP地址的实例方法

    查看连接mysql的IP地址的实例方法

    在本篇文章里小编给大家分享的是一篇关于查看连接mysql的IP地址的实例方法,有需要的朋友们可以参考下。
    2020-10-10
  • mysql 转换NULL数据方法(必看)

    mysql 转换NULL数据方法(必看)

    下面小编就为大家带来一篇mysql 转换NULL数据方法(必看)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • 解决MySQL存储时间出现不一致的问题

    解决MySQL存储时间出现不一致的问题

    这篇文章主要介绍了解决MySQL存储时间出现不一致的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04
  • 关于MySQL中的查询开销查看方法详解

    关于MySQL中的查询开销查看方法详解

    一个查询通常可以有很多种执行方式,并且返回同样的结果,而好的程序员应该是找到最好的方式,下面这篇文章主要给大家介绍了关于MySQL中查询开销查看方法的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2018-07-07
  • 详解MySQL中的pid与socket

    详解MySQL中的pid与socket

    不知道你有没有注意过,MySQL 启动时需要配置 pid 及 socket 文件路径。偶尔还会出现因 pid 文件找不到而启动失败的现象,那么 pid 与 socket 文件究竟是干什么用的呢?我们一起来看下本篇文章。
    2021-06-06
  • MySQL主从复制原理详情

    MySQL主从复制原理详情

    这篇文章主要介绍了MySQL主从复制原理详情,MySQL 主从复制是指数据可以从一个MySQL数据库服务器主节点复制到一个或多个从节点,文章围绕主题展开详细的内容介绍。感兴趣的小伙伴可以参考一下
    2022-06-06
  • mysql LOAD语句批量录入数据

    mysql LOAD语句批量录入数据

    本章的前面讨论如何使用SQL向一个表中插入数据。但是,如果你需要向一个表中添加许多条记录,使用SQL语句输入数据是很不方便的。
    2010-03-03
  • MySQL索引的一些常见面试题大全(2022年)

    MySQL索引的一些常见面试题大全(2022年)

    索引(Index)是帮助MySQL高效获取数据的数据结构,是对表中一列或多列值进行排序的结构,下面这篇文章主要给大家介绍了关于MySQL索引的一些常见面试题,文中介绍的非常详细,需要的朋友可以参考下
    2023-02-02
  • MySQL服务无法启动且服务没有报告任何错误的解决办法

    MySQL服务无法启动且服务没有报告任何错误的解决办法

    在启动项目时,发现昨天能够跑的项目今天跑不了了,一看原来是mysql数据库出现了问题,下面这篇文章主要给大家介绍了关于MySQL服务无法启动且服务没有报告任何错误的解决办法,需要的朋友可以参考下
    2023-05-05

最新评论