当前位置: 首页 > news >正文

mysql,PostgreSQL,Oracle数据库sql的细微差异(2) [whith as; group by; 日期引用]

sql示例(MySQL)

WITHtemp1 AS (SELECT name AS resultsFROM Users uJOIN MovieRating m ON u.user_id = m.user_idGROUP BY m.user_idORDER BY COUNT(*) DESC,left(name,1)LIMIT 1),temp2 AS (SELECT title AS resultsFROM Movies mJOIN MovieRating r ON m.movie_id = r.movie_idWHERE r.created_at BETWEEN '2020-02-01' AND '2020-02-29'GROUP BY m.titleORDER BY AVG(r.rating) DESC, m.title ASCLIMIT 1)SELECT * FROM temp1UNION ALLSELECT * FROM temp2;

 这里使用了CTE,即WITH子句中定义的临时表,temp1temp2 是临时的结果集,它们在 WITH 子句后面被创建,并在主查询中被引用,SELECT * FROM temp1 这部分被称作查询块(query block)或者查询语句(query statement)。

易犯的书写错误:

结果集缺乏( )括号 ; 

结果集之间缺失逗号; 

查询块的表名写错;

错写无效日期: 比如'2020-02-30',在 SQL 中,日期值必须有效。2 月并没有 31 日,这是一个无效的日期

whith  as

在oracle,mysql中,不允许在 CTE 内部使用 ORDER BY/LIMIT 组合,如果你需要在 CTE 中限制结果集,考虑使用子查询或者在 CTE 外部应用 LIMIT,

PostgreSQL可以,但是在多次引用 CTE 时,ORDER BY 的顺序不一定会被保留。此外,CTE 在 PostgreSQL 中总是被物化,这意味着它们的结果集会被实际存储,而不是仅仅作为一个临时的查询结果。这可能会导致性能问题,特别是当处理大量数据时.

解决方案:

  1. 在 CTE 外部使用 LIMIT

  2. 使用窗口函数,如 ROW_NUMBER(),来为每行分配一个唯一的序号,然后在 CTE 外部的查询中使用这个序号来限制结果集

  3.  PostgreSQL( 9.4 及以上版本),Oracle (12c 及以上版本) 可以在 CTE 中使用 FETCH FIRST 子句来限制结果集的大小

group by 

oracle和PostgreSQL里面,出现group by分组,则select 后的必须是聚合函数,或者在group by里出现的分组字段

在mysql没有这方面的要求 (上面的示例的temp1里面name)

日期格式

3个数据库都使用都使用单引号引用字符字面量

不同: mysql比较宽松,哪怕使用了双引号,日期格式正确也可以识别;

        oracle和PostgreSQL,对于字符字面量的引用只能是单引号;  

关于字面量的引用(3个数据库)

  • 字符串字面量(包括纯英文和中文)使用单引号。
  • 日期字面量使用单引号。
  • 数字字面量无需。

补充

标识符的引用:

oracle/PostgreSQL-----双引号" "

mysql-----反引号``

标识符:数据库对象,比如表名,列名,存储过程

避免日期的隐式转换

'2020-02-01'

oracle 用 to_date('日期','YYYY-MM-DD')

TO_DATE('2020-02-01', 'YYYY-MM-DD')

PostgreSQL 用  ::date 

'2020-02-01'::date

建议:

始终使用单引号来定义日期字符串,可以确保你的代码在不同的数据库系统中具有更好的可移植性和可读性。

日期存在隐式转换可能存在的问题

  1. 性能问题:这可能会增加查询的执行时间,尤其是在处理大量数据时。

  2. 数据一致性问题:如果应用程序在不同地方使用不同的日期格式,可能会导致数据不一致性,因为隐式转换可能在不同情况下产生不同的结果。

  3. 时区问题:如果数据库服务器和应用程序服务器位于不同的时区,隐式转换可能会导致时区处理上的问题

  4. 文化差异问题:不同的文化和地区可能有不同的日期格式习惯,隐式转换可能不会正确处理这些差异,导致日期被错误解析。

相关文章:

mysql,PostgreSQL,Oracle数据库sql的细微差异(2) [whith as; group by; 日期引用]

sql示例(MySQL) WITHtemp1 AS (SELECT name AS resultsFROM Users uJOIN MovieRating m ON u.user_id m.user_idGROUP BY m.user_idORDER BY COUNT(*) DESC,left(name,1)LIMIT 1),temp2 AS (SELECT title AS resultsFROM Movies mJOIN MovieRating r ON m.movie_id r.movie_…...

基于改进粒子群优化的无人机最优能耗路径规划

目录 1. Introduction2. Preliminaries2.1. Particle Swarm Optimization Algorithm2.2. Deep Deterministic Policy Gradient2.3. Calculation of the Total Output Power of the Quadcopter Battery 3.OptimalEnergyConsumptionPathPlanningBasedonPSO-DDPG3.1.ProblemModell…...

C#中通道(Channels)的应用之(生产者-消费者模式)

一.生产者-消费者模式概述 生产者-消费者模式是一种经典的设计模式,它将数据的生成(生产者)和处理(消费者)分离到不同的模块或线程中。这种模式的核心在于一个共享的缓冲区,生产者将数据放入缓冲区&#x…...

git: hint:use --reapply-cherry-picks to include skipped commits

问: 当我在feture分支写完功能,切换到dev更新了远端dev代码,切回feture分支,git rebase dev分支后出现报错: warning skipped previously applied commit 709xxxx hint:use --reapply-cherry-picks to include skippe…...

AI:对比ChatGPT这类聊天机器人,人形机器人对人类有哪些不一样的影响?

人形机器人与像ChatGPT这样的聊天机器人相比,虽然都属于人工智能技术的应用,但由于其具备的物理形态和与环境的互动能力,它们对人类的影响会有很大的不同。下面从多个角度进行对比,阐述它们各自对人类的不同影响: 1. …...

vue3 +ts 学习记录

1 父子传参 父传子 父组件 <TestFuzichuancan :title"title"/> const title 父组件标题子组件 import { defineProps } from vue; interface Props {title?: string,arr: number[]; } const props withDefaults(defineProps<Props>(), {title: 默认…...

微服务的配置共享

1.什么是微服务的配置共享 微服务架构中&#xff0c;配置共享是一个重要环节&#xff0c;它有助于提升服务间的协同效率和数据一致性。以下是对微服务配置共享的详细阐述&#xff1a; 1.1.配置共享的概念 配置共享是指在微服务架构中&#xff0c;将某些通用或全局的配置信息…...

Scala分布式语言二(基础功能搭建、面向对象基础、面向对象高级、异常、集合)

章节3基础功能搭建 46.函数作为值三 package cn . itbaizhan . chapter03 // 函数作为值&#xff0c;函数也是个对象 object FunctionToTypeValue { def main ( args : Array [ String ]): Unit { //Student stu new Student() /*val a ()>{"GTJin"…...

Chromium 132 编译指南 Windows 篇 - 配置核心环境变量 (三)

1. 引言 在之前的 Chromium 编译指南系列文章中&#xff0c;我们已经完成了编译前的准备工作以及 depot_tools 工具的安装与配置。本篇我们将聚焦于 Chromium 编译过程中至关重要的环境变量设置&#xff0c;这些配置是您顺利进行 Chromium 构建的基石。 2. 启用本地编译&…...

开源文件存储分享平台Seafile部署与应用

Seafile 是一款开源的企业云盘,注重可靠性和性能,支持全平台客户端。Seafile 内置协同文档 SeaDoc ,让协作撰写、管理和发布文档更便捷。适用于团队协作、文件存储和同步的开源解决方案,它提供了可靠、安全和易用的云存储服务。主要有以下特点: 文件存储和同步:Seafile 允…...

MYSQL-创建数据库 CREATE DATABASE (十一)

13.1.11 CREATE DATABASE 语句 -- 创建 数据库的 CREATE 权限 CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db_name[create_option] ...create_option: [DEFAULT] {CHARACTER SET [] charset_name| COLLATE [] collation_name } -- 删除 数据库具有 DROP 权限 DROP {DATABASE…...

Java高频面试之SE-11

hello啊&#xff0c;各位观众姥爷们&#xff01;&#xff01;&#xff01;本牛马baby今天又来了&#xff01;哈哈哈哈哈嗝&#x1f436; Java中是引用传递还是值传递&#xff1f; 在 Java 中&#xff0c;方法参数传递是通过 值传递 的方式实现的&#xff0c;但这可能会引起一…...

C#结构体,枚举,泛型,事件,委托--10

目录 一.结构体 二.特殊的结构体(ref struct): 三.枚举 四.泛型 泛型的使用: 1.泛型类:定义一个泛型类,使用类型参数T 2.泛型方法:在方法定义中使用类型参数 3.泛型接口 五.委托及泛型委托 委托 泛型委托 六.事件 事件: 泛型事件:使用泛型委托&#xff08;如Event…...

MapReduce完整工作流程

1、mapreduce工作流程(终极版) 0. 任务提交 1. 拆-split逻辑切片--任务切分。 FileInputFormat--split切片计算工具 FileSplit--单个计算任务的数据范围。 2. 获得split信息和个数。 MapTask阶段 1. 读取split范围内的数据。k(偏移量)-v(行数据) 关键API&#xff1a;TextI…...

网络编程(1)

网络编程概述 Java是 Internet 上的语言&#xff0c;它从语言级上提供了对网络应用程序的支持&#xff0c;程序员能够很容易开发常见的网络应用程序。 Java提供的网络类库&#xff0c;可以实现无痛的网络连接&#xff0c;联网的底层细节被隐藏在 Java 的本机安装系统里&#…...

mysql中创建计算字段

目录 1、计算字段 2、拼接字段 3、去除空格和使用别名 &#xff08;1&#xff09;去除空格 &#xff08;2&#xff09;使用别名&#xff1a;AS 4、执行算术计算 5、小结 博主用的是mysql8 DBMS&#xff0c;附上示例资料&#xff1a; 百度网盘链接: https://pan.baidu.co…...

【算法】判断一个链表是否为回文结构

问&#xff1a; 给定一个单链表的头节点head&#xff0c;请判断该链表是否为回文结构 例&#xff1a; 1 -> 2 -> 1返回true&#xff1b;1 -> 2 -> 2 -> 1返回true&#xff1b;15 -> 6 -> 15返回true 答&#xff1a; 笔试&#xff1a;初始化一个栈用来…...

计算机网络之---ICMP协议与Ping命令

ICMP 协议 ICMP (Internet Control Message Protocol) 是一种网络层协议&#xff0c;主要用于在 IP 网络中传递控制消息。ICMP 主要用于网络设备之间的故障报告和诊断&#xff0c;帮助设备检测网络连接问题。它是 IP 协议的核心部分之一&#xff0c;用于发送错误消息和操作信息…...

【硬件介绍】Type-C接口详解

一、Type-C接口概述 Type-C接口特点&#xff1a;以其独特的扁头设计和无需区分正反两面的便捷性而广受欢迎。这种设计大大提高了用户的使用体验&#xff0c;避免了传统USB接口需要多次尝试才能正确插入的问题。Type-C接口内部结构&#xff1a;内部上下两排引脚的设计虽然可能不…...

【Pandas】pandas Series rtruediv

Pandas2.2 Series Binary operator functions 方法描述Series.add()用于对两个 Series 进行逐元素加法运算Series.sub()用于对两个 Series 进行逐元素减法运算Series.mul()用于对两个 Series 进行逐元素乘法运算Series.div()用于对两个 Series 进行逐元素除法运算Series.true…...

FreeRTOS实战指南:从定时器、中断到系统调优的进阶之路

1. FreeRTOS定时器实战&#xff1a;从基础到高级应用 在嵌入式系统中&#xff0c;定时器是实现精确时序控制的核心组件。FreeRTOS提供的软件定时器功能&#xff0c;比硬件定时器更加灵活易用。我曾在智能家居项目中用FreeRTOS定时器实现过温湿度传感器的周期性采集&#xff0c…...

Golang怎么用Task替代Makefile_Golang如何用go-task编写跨平台的任务脚本文件【教程】

go-task 是用 Go 编写的跨平台任务编排工具&#xff0c;本质区别于 Makefile&#xff1a;它用 YAML 定义任务、不依赖 shell 缩进、默认不继承父环境变量、无增量构建、支持变量注入与平台条件判断&#xff0c;且单文件分发。go-task 是什么&#xff0c;和 Makefile 有什么本质…...

Ostrakon-VL-8B部署指南:快速搭建支持图片问答的智能系统

Ostrakon-VL-8B部署指南&#xff1a;快速搭建支持图片问答的智能系统 1. 系统概述 Ostrakon-VL-8B是一款专为零售和餐饮场景优化的多模态视觉理解系统。它能像人类一样"看懂"图片内容&#xff0c;并回答与图片相关的各种问题。 这个系统基于Qwen3-VL-8B模型微调而…...

AI辅助开发新思路:让快马平台生成风车动漫智能推荐与摘要代码

用AI辅助开发提升动漫网站体验 最近在做一个动漫网站项目&#xff0c;需要实现智能推荐和内容摘要功能。传统开发方式需要自己写复杂的算法&#xff0c;但借助InsCode(快马)平台的AI辅助功能&#xff0c;可以快速生成代码框架&#xff0c;大大提升开发效率。下面分享我的实现思…...

5步轻松打造随身游戏库:Playnite便携版终极配置指南

5步轻松打造随身游戏库&#xff1a;Playnite便携版终极配置指南 【免费下载链接】Playnite Video game library manager with support for wide range of 3rd party libraries and game emulation support, providing one unified interface for your games. 项目地址: https…...

G-Helper终极指南:如何免费优化华硕笔记本性能,告别Armoury Crate臃肿体验

G-Helper终极指南&#xff1a;如何免费优化华硕笔记本性能&#xff0c;告别Armoury Crate臃肿体验 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across …...

Windows Defender的MsMpEng.exe为什么总在“瞎忙”?从机制到应对的深度解读

Windows Defender的MsMpEng.exe高占用现象&#xff1a;机制解析与精准优化策略 你是否经历过这样的场景&#xff1a;正在紧急编译代码时&#xff0c;风扇突然狂转&#xff0c;任务管理器里MsMpEng.exe的CPU使用率飙升至90%&#xff1b;或者拷贝大型设计文件时&#xff0c;系统卡…...

COMSOL多场耦合地应力平衡开挖与衬砌支护案例:带衬砌与钢衬支护的实践研究

COMSOL 地应力平衡后开挖及衬砌支护案例&#xff08;带衬砌、钢衬&#xff09;隧道开挖模拟最头疼的就是初始地应力场的平衡问题。前些天用COMSOL折腾了个带衬砌支护的案例&#xff0c;今天把关键步骤拆开说说。咱们直接从地应力平衡开始&#xff0c;到开挖后钢衬安装一气呵成。…...

P1103 书本整理【洛谷算法习题】

P1103 书本整理 网页链接 P1103 书本整理 题目描述 Frank 是一个非常喜爱整洁的人。他有一大堆书和一个书架&#xff0c;想要把书放在书架上。书架可以放下所有的书&#xff0c;所以 Frank 首先将书按高度顺序排列在书架上。但是 Frank 发现&#xff0c;由于很多书的宽度不…...

dfs经典例题——迷宫问题(利用二维数组优化方向判断)

思路&#xff1a;首先关于方向问题&#xff0c;我们可以设定一个默认方向&#xff0c;比如先默认向右&#xff0c;触底向下&#xff0c;然后再是向左向上。只需要平行在dfs函数中即可&#xff0c;每次递归会自动依次按照if条件进行合适方向的查找初始量&#xff1a;地图数组&am…...