解决sql字符串
根据你描述的情况以及调试截图中的内容,我可以确认你的 sql
字符串在 Python 中由于转义字符的问题,可能导致在 Oracle 中运行时出错。
以下是一些排查和修改建议:
问题分析
-
转义字符问题:
- 在调试界面中可以看到,
DECODE(c.bin_flag, 1, '\\Pass\\', '\\Fail\\')
中多余的\\
是 Python 中的转义字符,可能在实际执行 SQL 时未被正确解析。 - 在 Python 中,字符串中的
\
本身需要通过\\
表示,但在 SQL 中不需要这种转义。
- 在调试界面中可以看到,
-
ORA-00911 错误:
- Oracle 的 ORA-00911 通常指的是 SQL 语法问题,例如非法字符或未正确转义的符号。
- 你当前 SQL 语句的拼接部分可能未正确处理这种问题,尤其是在
DECODE
和REGEXP_REPLACE
中的字符串内容。
修复建议
方法 1:使用原始字符串 r''
你可以将 SQL 中的字符串用 Python 的原始字符串方式表示,避免手动转义符号。改写如下:
sql = r"""SELECT a.*, b.bin_code, b.merge_count, b.first_count, b.rt_count, DECODE(c.bin_flag, 1, 'Pass', 'Fail') P_F ,REGEXP_REPLACE(ROUND(b.merge_count / die_tested * 100, 2), '^\.', '0.') || '%' Percent FROM (SELECT a.* FROM (SELECT t.*, ROW_NUMBER() OVER(PARTITION BY t.lot_id ORDER BY t.eda_load_time DESC) rn FROM SJTYS.ft_rawdata t WHERE t.lot_id = :lotid AND t.step LIKE 'ST%') a WHERE a.rn = 1) a LEFT JOIN SJTYS.ft_rawdata_bin_sum b ON a.id = b.id AND b.bin_type = 'H' LEFT JOIN SJTYS.ft_bdf_definition c ON a.bdf_file_name = c.bdf_file_name AND b.bin_code = c.bin_code AND b.bin_type = c.bin_type WHERE DECODE(c.bin_flag, 1, 'Pass', 'Fail') = 'Pass' ORDER BY b.bin_code"""
这里的改进:
- 使用了原始字符串
r"""..."""
,避免手动转义引入的问题。 - 用
:lotid
替代了直接拼接lotid
的方式(推荐使用参数化查询)。
方法 2:参数化查询
直接拼接字符串容易导致 SQL 注入风险。推荐使用参数化查询:
def Query_Info_First(prodid, lotid):connection = cx_Oracle.connect("user", "uerpwd", "ip:port/service")cursor = connection.cursor()sql = """SELECT a.*, b.bin_code, b.merge_count, b.first_count, b.rt_count, DECODE(c.bin_flag, 1, 'Pass', 'Fail') P_F ,REGEXP_REPLACE(ROUND(b.merge_count / die_tested * 100, 2), '^\.', '0.') || '%' Percent FROM (SELECT a.* FROM (SELECT t.*, ROW_NUMBER() OVER(PARTITION BY t.lot_id ORDER BY t.eda_load_time DESC) rn FROM SJTYS.ft_rawdata t WHERE t.lot_id = :lotid AND t.step LIKE 'ST%') a WHERE a.rn = 1) a LEFT JOIN SJTYS.ft_rawdata_bin_sum b ON a.id = b.id AND b.bin_type = 'H' LEFT JOIN SJTYS.ft_bdf_definition c ON a.bdf_file_name = c.bdf_file_name AND b.bin_code = c.bin_code AND b.bin_type = c.bin_type WHERE DECODE(c.bin_flag, 1, 'Pass', 'Fail') = 'Pass' ORDER BY b.bin_code"""cursor.execute(sql, lotid=lotid)MultiTable_INFO = cursor.fetchall()cursor.close()connection.close()return MultiTable_INFO
方法验证
建议你按照以下步骤调试:
- 将上面的方法替换到你的代码中,优先使用 方法 2(参数化查询)。
- 检查是否仍有 ORA-00911 报错。如果仍有问题:
- 打印
sql
字符串的最终值,确保语句和 Oracle 中运行的语句完全一致。 - 手动在 Oracle 中再次运行以验证语法是否正确。
- 打印
常见注意事项
-
转义字符问题:
- 避免在 SQL 中直接使用 Python 的
\
转义字符,建议使用单引号''
或原始字符串。
- 避免在 SQL 中直接使用 Python 的
-
字符串拼接:
- SQL 语句中直接拼接变量容易导致语法错误,使用参数化查询可以避免此类问题。
-
Oracle 函数和字段名:
- 确保 SQL 中使用的字段名、表名等正确无误,尤其是别名、函数(如
REGEXP_REPLACE
)是否支持。
- 确保 SQL 中使用的字段名、表名等正确无误,尤其是别名、函数(如
请根据我的建议调整后测试!如果仍有问题,可以进一步提供更多信息。
相关文章:
解决sql字符串
根据你描述的情况以及调试截图中的内容,我可以确认你的 sql 字符串在 Python 中由于转义字符的问题,可能导致在 Oracle 中运行时出错。 以下是一些排查和修改建议: 问题分析 转义字符问题: 在调试界面中可以看到,DEC…...

深度解析:Android APP集成与拉起微信小程序开发全攻略
目录 一、背景以及功能介绍 二、Android开发示例 2.1 下载 SDK 2.2 调用接口 2.3 获取小程序原始Id 2.4 报错提示:bad_param 2.4.1 错误日志 2.4.2 解决方案 相关推荐 一、背景以及功能介绍 需求:产品经理需要APP跳转到公司的小程序(最好指定页…...

Leetcode 被围绕的区域
算法思想(解题思路): 这道题的核心是 将所有被边界包围的 O 保留下来,而将其他被围绕的 O 转换为 X。为了实现这一目标,我们可以分三步完成: 第一步:标记边界及其相连的 O 为特殊标记ÿ…...

ssm框架-spring-spring声明式事务
声明式事务概念 声明式事务是指使用注解或 XML 配置的方式来控制事务的提交和回滚。 开发者只需要添加配置即可, 具体事务的实现由第三方框架实现,避免我们直接进行事务操作! 使用声明式事务可以将事务的控制和业务逻辑分离开来,提…...
React第五节 组件三大属性之 props 用法详解
特性 a、props最好是仅限于父子上下级之间的数据传递,如果是祖孙多级之间传递属性,可以考虑使用props是否合适,或者使用替代方案 useContext() 或者使用 redux状态管理; b、props 中的属性是只读属性,如果想修改其中的…...

测评部署和管理 WordPress 最方便的面板
新版宝塔面板快速搭建WordPress新手教程 - 倚栏听风-Morii - 博客园 初学者使用1Panel面板快速搭建WordPress网站 - 倚栏听风-Morii - 博客园 可以看到,无论是宝塔还是1Panel,部署和管理WordPress都有些繁琐,而且还需要额外去配置Nginx和M…...
【系统分析师】-2024年11月论文-论DevOps开发
1、题目要求 论Devops及其应用。Devops是一组过程、方法与系统的统称,用于促进开发、技术运营和质量保障部门之间的沟通,协作与整合。它是一种重视软体开发人员和工厂运维技术人员之间沟通合作的模式。透过自动化“软件交付”和“架构变更”的流程&…...
算法【子数组最大累加和问题与扩展】
子数组最大累加和问题是一个非常经典的问题,也比较简单。但是扩展出的问题很多,在笔试、面试中特别常见,扩展出的问题很多非常有趣,解法也比较巧妙。 下面通过一些题目来加深理解。 题目一 测试链接:https://leetcode…...
小程序23-页面的跳转:navigation 组件详解
小程序中,如果需要进行跳转,需要使用 navigation 组件,常用属性: 1.url :当前小程序内的跳转链接 2.open-type:跳转方式 navigate:保留当前页面,跳转应用内的某个页面,…...

AI社媒引流工具:解锁智能化营销的新未来
在数字化浪潮的推动下,社交媒体成为品牌营销的主战场。然而,面对海量的用户数据和日益复杂的运营需求,传统营销方法显得力不从心。AI社媒引流王应运而生,帮助企业在多平台中精准触达目标用户,提升营销效率和效果。 1.…...

【Node.js】全面解析 Node.js 安全最佳实践:保护您的应用
Node.js 是一种强大的 JavaScript 运行时,广泛用于构建现代 Web 应用和 API。然而,由于其开放性和异步特性,Node.js 应用容易受到多种安全威胁的攻击,比如 SQL 注入、跨站脚本 (XSS) 和拒绝服务攻击 (DoS)。在本文中,我…...

Docker 用法详解
文章目录 一、Docker 快速入门1.1 部署 MYSQL1.2 命令解读: 二、Docker 基础2.1 常见命令:2.1.1 命令介绍:2.1.2 演示:2.1.3 命令别名: 2.2 数据卷:2.2.1 数据卷简介:2.2.2 数据卷命令ÿ…...

Python小游戏28——水果忍者
首先,你需要安装Pygame库。如果你还没有安装,可以使用以下命令进行安装: 【bash】 pip install pygame 《水果忍者》游戏代码: 【python】 import pygame import random import sys # 初始化Pygame pygame.init() # 设置屏幕尺寸 …...
Kafka Offset 自动提交和手动提交 - 漏消费与重复消费
目录 1. 引言 2. Offset 提交方式概述 2.1 自动提交 Offset 2.2 手动提交 Offset 3. 漏消费与重复消费的问题分析 3.1 自动提交模式下的漏消费和重复消费 漏消费 重复消费 3.2 手动提交模式下的漏消费和重复消费 漏消费 重复消费 4. 自动提交与手动提交的选择 4.1…...
Vue3父组件和子组件
子组件暴露方法给父组件,父组件传值 子组件 const editCalendar (value: string) > {console.log(获取父组件的值, value)};//暴露给外部调用defineExpose({editCalendar,}); 父组件 <template> <CalendarEdit ref"editRef" /> </…...
Linux 定时任务全解析
文章目录 一、Cron 服务1.1安装1.2配置文件格式1.3使用方法1.4系统级与用户级 Cron 任务区别 二、At 服务2.1安装2.2工作原理2.3使用方法 一、Cron 服务 1.1安装 在大多数 Linux 发行版中,Cron 服务通常已经默认安装。例如在 Ubuntu 系统中,可以通过以…...
XLNet——打破 BERT 局限的预训练语言模型
近年来,深度学习在自然语言处理(NLP)领域取得了革命性进展,其中 BERT 的出现标志着双向语言建模的强大能力。然而,BERT 也存在一些局限性,限制了其在生成任务中的表现。2019 年,由 Google 和 Ca…...

开源代码统计工具cloc的简单使用
一.背景 公司之前开发了个小系统,要去申请著作权,需要填写代码数量。应该怎么统计呢?搜索了一下,还是用开源工具cloc吧!我的操作系统是windows,代码主要是java项目和vue项目。 二.到哪里找 可以去官方下载…...

如何创建一个项目用于研究element-plus的原理
需求:直接使用element-plus未封装成组件的源码,创建一个项目,可以使用任意的element-plus组件,可以深度研究组件的运行。例如研究某一个效果,如果直接在node_modules修改elment-plus打包之后的那些js、mjs代码…...

单片机进阶硬件部分_day2_项目实践
设计要求 从绘制原理图到画PCB板,完成智能云衣柜项目 STM32 (Modbus)云IOT衣物云端管理 华为PCB布线规范 基于IoT的智享家主控系统 步骤分析 需求分析 器件选型绘制原理图(器件连接)PCB布局、布线泪滴、铺铜、添加丝印…...
KubeSphere 容器平台高可用:环境搭建与可视化操作指南
Linux_k8s篇 欢迎来到Linux的世界,看笔记好好学多敲多打,每个人都是大神! 题目:KubeSphere 容器平台高可用:环境搭建与可视化操作指南 版本号: 1.0,0 作者: 老王要学习 日期: 2025.06.05 适用环境: Ubuntu22 文档说…...

使用VSCode开发Django指南
使用VSCode开发Django指南 一、概述 Django 是一个高级 Python 框架,专为快速、安全和可扩展的 Web 开发而设计。Django 包含对 URL 路由、页面模板和数据处理的丰富支持。 本文将创建一个简单的 Django 应用,其中包含三个使用通用基本模板的页面。在此…...

解决Ubuntu22.04 VMware失败的问题 ubuntu入门之二十八
现象1 打开VMware失败 Ubuntu升级之后打开VMware上报需要安装vmmon和vmnet,点击确认后如下提示 最终上报fail 解决方法 内核升级导致,需要在新内核下重新下载编译安装 查看版本 $ vmware -v VMware Workstation 17.5.1 build-23298084$ lsb_release…...

【大模型RAG】Docker 一键部署 Milvus 完整攻略
本文概要 Milvus 2.5 Stand-alone 版可通过 Docker 在几分钟内完成安装;只需暴露 19530(gRPC)与 9091(HTTP/WebUI)两个端口,即可让本地电脑通过 PyMilvus 或浏览器访问远程 Linux 服务器上的 Milvus。下面…...

EtherNet/IP转DeviceNet协议网关详解
一,设备主要功能 疆鸿智能JH-DVN-EIP本产品是自主研发的一款EtherNet/IP从站功能的通讯网关。该产品主要功能是连接DeviceNet总线和EtherNet/IP网络,本网关连接到EtherNet/IP总线中做为从站使用,连接到DeviceNet总线中做为从站使用。 在自动…...
在web-view 加载的本地及远程HTML中调用uniapp的API及网页和vue页面是如何通讯的?
uni-app 中 Web-view 与 Vue 页面的通讯机制详解 一、Web-view 简介 Web-view 是 uni-app 提供的一个重要组件,用于在原生应用中加载 HTML 页面: 支持加载本地 HTML 文件支持加载远程 HTML 页面实现 Web 与原生的双向通讯可用于嵌入第三方网页或 H5 应…...

云原生安全实战:API网关Kong的鉴权与限流详解
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、基础概念 1. API网关(API Gateway) API网关是微服务架构中的核心组件,负责统一管理所有API的流量入口。它像一座…...
jmeter聚合报告中参数详解
sample、average、min、max、90%line、95%line,99%line、Error错误率、吞吐量Thoughput、KB/sec每秒传输的数据量 sample(样本数) 表示测试中发送的请求数量,即测试执行了多少次请求。 单位,以个或者次数表示。 示例:…...

华为OD机试-最短木板长度-二分法(A卷,100分)
此题是一个最大化最小值的典型例题, 因为搜索范围是有界的,上界最大木板长度补充的全部木料长度,下界最小木板长度; 即left0,right10^6; 我们可以设置一个候选值x(mid),将木板的长度全部都补充到x,如果成功…...

Linux部署私有文件管理系统MinIO
最近需要用到一个文件管理服务,但是又不想花钱,所以就想着自己搭建一个,刚好我们用的一个开源框架已经集成了MinIO,所以就选了这个 我这边对文件服务性能要求不是太高,单机版就可以 安装非常简单,几个命令就…...