찾다
백엔드 개발GolangGolang에서 'ORA-00911: 잘못된 문자' 오류를 해결하는 방법은 무엇입니까?

如何解决 Golang 中的错误“ORA-00911:无效字符”?

Golang 개발 과정에서 "ORA-00911: 잘못된 문자"와 같은 오류가 가끔 발생합니다. 이 오류는 일반적으로 SQL 문에 잘못된 문자를 사용하여 발생합니다. 이 문제를 해결하기 위해 몇 가지 간단한 방법을 사용할 수 있습니다. 먼저, SQL 문을 실행하기 전에 해당 문에 특수 문자나 유효하지 않은 문자가 있는지 주의 깊게 확인해야 합니다. 둘째, 오류를 방지하기 위해 특수 문자가 포함된 필드나 값을 따옴표로 묶을 수 있습니다. 또한 SQL 문에서 특수 문자가 올바르게 인식되고 처리되도록 이스케이프 문자를 사용하여 특수 문자를 처리할 수도 있습니다. 이러한 방법을 통해 Golang의 "ORA-00911: 잘못된 문자" 문제를 효과적으로 해결하고 프로그램이 정상적으로 실행되도록 할 수 있습니다.

질문 내용

다음 함수를 호출할 때 "ORA-00911: 잘못된 문자" 오류가 발생했습니다. 하드코딩된 값이 포함된 SQL 쿼리를 사용하는 경우(현재는 아래 코드 조각에 주석 처리되어 있음) 문제 없이 Postman의 JSON 응답에서 데이터베이스 레코드를 가져올 수 있습니다. 그래서 제 주장이 잘못 된 것 같습니다. 참고로 저는 "github.com/sijms/go-ora/v2" 패키지를 사용하여 oracle db에 연결하고 있습니다. 또한 "DashboardRecordsRequest" 구조는 데이터 모델 패키지에 있지만 참조용으로 아래 스니펫에 붙여넣었습니다. POC를 수행할 때 저장 프로시저를 사용하여 Oracle과 상호 작용할 것이라는 점에 유의하십시오.

우체부 요청 로드:

으아악

실행 코드:

으아악

요청 테이블 구조:

으아악

오류:

<code>{
    "username": "UserABC",
    "startindex": 0,
    "pagesize": 10,
    "sortby": "requestnumber",
    "sortorder": "DESC"
}
</code>

해결 방법

즉각적인 문제는 JDBC 스타일 ? 绑定占位符,而不是预期的 :var 形式。从 go-ora 패키지를 사용하고 있다는 것입니다. 문서 에서 다음을 사용하고 있다고 말합니다.

따라서 귀하의 stmt은 다음과 같아야 합니다:

으아악

하지만 변수 이외의 다른 것을 바인딩할 수 없으므로 sortorder 변수를 제거하고 다음을 수행하면 전혀 변수로 사용할 수 없습니다.

으아악

이것은 작동하는 것처럼 보이지만 정렬은 값이 아닌 리터럴 열 이름을 기준으로 정렬되므로 ORDER BY 'requestnumber' 的等效项运行,而不是 ORDER BY requestnumber처럼 작동하므로 원하는 대로 작동하지 않습니다. 그리고 해당 상수 문자열을 기준으로 정렬하면 아무 것도 달성되지 않습니다.

문에 주문 기준을 포함해야 합니다.

으아악

dbfiddle은 PL/SQL 동적 커서를 단순화된 등가물로 사용하여 세 가지 버전(잘못된 버전, 예상대로 주문되지 않은 버전, 최종적으로는 정상적으로 주문된 버전)을 표시합니다.

그러나 SQL 주입을 다시 방지하려면 이러한 입력을 삭제해야 합니다.

위 내용은 Golang에서 'ORA-00911: 잘못된 문자' 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 stackoverflow에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
'문자열'패키지를 사용하여 단계별로 문자열을 조작하는 방법'문자열'패키지를 사용하여 단계별로 문자열을 조작하는 방법May 13, 2025 am 12:12 AM

GO의 문자열 패키지는 다양한 문자열 조작 기능을 제공합니다. 1) 문자열을 사용하여 기판을 확인하십시오. 2) strings.split을 사용하여 문자열을 서브 스트링 슬라이스로 분할하십시오. 3) 문자열을 통해 문자열을 병합합니다. 4) 문자열의 시작과 끝에서 strings.trimspace 또는 strings.trim을 사용하여 공백 또는 지정된 문자를 제거하십시오. 5) 지정된 모든 하위 문구를 문자열로 교체하십시오. 6) strings.hasprefix 또는 strings.hassuffix를 사용하여 문자열의 접두사 또는 접미사를 확인하십시오.

Go Strings 패키지 : 코드를 개선하는 방법?Go Strings 패키지 : 코드를 개선하는 방법?May 13, 2025 am 12:10 AM

Go Language Strings 패키지를 사용하면 코드 품질이 향상 될 수 있습니다. 1) strings.join ()을 사용하여 성능 오버 헤드를 피하기 위해 문자열 배열을 우아하게 연결하십시오. 2) strings.split () 및 strings.contains ()를 결합하여 텍스트를 처리하고 사례 민감도 문제에주의를 기울입니다. 3) 문자열의 남용을 피하고 ()을 replace ()하고 많은 수의 대체에 정규 표현식을 사용하는 것을 고려하십시오. 4) strings.builder를 사용하여 자주 스 플라이 싱 스트링의 성능을 향상시킵니다.

Go Bytes 패키지에서 가장 유용한 기능은 무엇입니까?Go Bytes 패키지에서 가장 유용한 기능은 무엇입니까?May 13, 2025 am 12:09 AM

GO의 바이트 패키지는 바이트 슬라이싱을 처리하기위한 다양한 실용적인 기능을 제공합니다. 1. BYTES는 바이트 슬라이스에 특정 시퀀스가 ​​포함되어 있는지 확인하는 데 사용됩니다. 2.Bytes.split은 바이트 슬라이스를 작은 피스로 분할하는 데 사용됩니다. 3.Bytes.join은 여러 바이트 슬라이스를 하나로 연결하는 데 사용됩니다. 4.bytes.trimspace는 바이트 슬라이스의 전면 및 후면 블랭크를 제거하는 데 사용됩니다. 5.Bytes.equal은 두 바이트 슬라이스가 동일인지 비교하는 데 사용됩니다. 6.bytes.index는 LargersLices에서 하위 슬라이스의 시작 지수를 찾는 데 사용됩니다.

GO의 '인코딩/바이너리'패키지로 바이너리 데이터 처리 마스터 링 : 포괄적 인 가이드GO의 '인코딩/바이너리'패키지로 바이너리 데이터 처리 마스터 링 : 포괄적 인 가이드May 13, 2025 am 12:07 AM

Theencoding/BinaryPackageInsentialBecauseItProvideAstandAdizedWayStandwriteBinaryData, Cross-PlatformCompatibility 및 HandshandlingDifferentendianness.ItoffersFunctionsLikeRead, Write, andwriteUvarIntForPrecisControloverbinary

'바이트'패키지 빠른 참조로 이동하십시오'바이트'패키지 빠른 참조로 이동하십시오May 13, 2025 am 12:03 AM

thebackageoiscrucialforhandlingbyteslicesandbuffers, ontowtoolsforefficiledmemorymanagementanddatamanipulation.1) itprovideFunctionItieslikeCreatingBuffers, 비교 및 ​​교체/교체, 2) forlargedatasets, 사용

마스터 링 GO 줄 : '문자열'패키지에 대한 깊은 다이빙마스터 링 GO 줄 : '문자열'패키지에 대한 깊은 다이빙May 12, 2025 am 12:05 AM

텍스트 데이터를 처리하는 도구를 제공하고 기본 문자열에서 고급 정규 표현식에 이르기까지 텍스트 데이터를 처리 할 수있는 도구를 제공하기 때문에 이동 중 "문자열"패키지에주의해야합니다. 1) "Strings"패키지는 성능 문제를 피하기 위해 문자열을 스플 라이스하는 데 사용되는 결합 기능과 같은 효율적인 스트링 작업을 제공합니다. 2) 포함 함수와 같은 고급 함수가 포함되어있어 문자열에 특정 문자 세트가 포함되어 있는지 확인합니다. 3) 교체 함수는 문자열의 하위 문자열을 대체하는 데 사용되며 교체 순서 및 사례 감도에주의를 기울여야합니다. 4) 분할 함수는 분리기에 따라 문자열을 분할 할 수 있으며 종종 정규 발현 처리에 사용됩니다. 5) 사용 할 때 성능을 고려해야합니다.

Go의 '인코딩/이진'패키지 : 이진 작업을위한 이동Go의 '인코딩/이진'패키지 : 이진 작업을위한 이동May 12, 2025 am 12:03 AM

"인코딩/바이너리"패키지 인테이블 링 베이너리 데이터, 1) ItsupportsBothlittle-endianandbig-endianByteorders, CruialCross-SystemCompatibility .2) ThePackagealLowworkingwithcus

바이트 슬라이스 조작 자습서 : '바이트'패키지 마스터 링바이트 슬라이스 조작 자습서 : '바이트'패키지 마스터 링May 12, 2025 am 12:02 AM

바이트 패키지를 GO에서 마스터하면 코드의 효율성과 우아함을 향상시키는 데 도움이 될 수 있습니다. 1) 바이트 패키지는 이진 데이터를 구문 분석, 네트워크 프로토콜 및 메모리 관리에 중요합니다. 2) BYTES.BUFFER를 사용하여 점차적으로 바이트 슬라이스를 작성하십시오. 3) 바이트 패키지는 바이트 슬라이스 검색, 교체 및 세분화 기능을 제공합니다. 4) BYTES.READER 유형은 특히 I/O 작업에서 바이트 슬라이스의 데이터를 읽는 데 적합합니다. 5) Bytes 패키지는 GO의 가비지 수집기와 협력하여 빅 데이터 처리의 효율성을 향상시킵니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기