如何解决 Golang 中的错误'ORA-00911:无效字符”?
在Golang开发过程中,我们有时会遇到"ORA-00911: 无效字符"这样的错误。这种错误通常是由于在SQL语句中使用了无效的字符而引起的。要解决这个问题,我们可以采取一些简单的方法。首先,在执行SQL语句之前,我们应该仔细检查语句中是否存在特殊字符或无效字符。其次,我们可以尝试使用引号将包含特殊字符的字段或值括起来,以避免出现错误。另外,还可以使用转义字符来处理特殊字符,确保其在SQL语句中被正确地识别和处理。通过这些方法,我们可以有效地解决Golang中出现"ORA-00911: 无效字符"的问题,确保我们的程序能够正常运行。
问题内容
我在调用以下函数时遇到错误“ORA-00911:无效字符”。如果我使用带有硬编码值的 SQL 查询(截至目前,它已在下面的代码片段中注释掉),那么我可以在邮递员中以 JSON 响应获取数据库记录,没有任何问题。所以,看起来我的论点做错了。仅供参考,我正在使用“github.com/sijms/go-ora/v2”包连接到 oracle db。 另外,“DashboardRecordsRequest”结构位于数据模型包中,但我已将其粘贴到下面的代码片段中以供参考。 请注意,当我进行 POC 时,我们将使用存储过程与 Oracle 交互。
邮差请求负载:
<code>{ "username": "UserABC", "startindex": 0, "pagesize": 10, "sortby": "requestnumber", "sortorder": "DESC" } </code>
执行代码:
<code>type DashboardRecordsRequest struct { Username string `json:"username"` StartIndex int `json:"startindex"` PageSize int `json:"pagesize"` SortBy string `json:"sortby"` SortOrder string `json:"sortorder"` } func GetDashboardActiveRequestRecords(request datamodel.DashboardRecordsRequest) ([]datamodel.ActiveRequestRecord, error) { sortby := request.SortBy sortorder := request.SortOrder startindex := request.StartIndex pagesize := request.PageSize activerecords := []datamodel.ActiveRequestRecord{} slog.Info("Verify values", slog.String("sortby", sortby), slog.String("sortorder", sortorder), slog.Int("startindex", startindex), slog.Int("pagesize", pagesize)) dbconn, err := getDBConnection() if err != nil { logger.Error("Could not connect to database") return activerecords, err } stmt, err := dbconn.Prepare("SELECT requestnumber, requeststatus, NVL(requestor, 'N/A'), NVL(pendingwith, 'N/A'), NVL(processtype, 'N/A'), actiondate FROM requests WHERE requeststatus = 'PENDINGAPPROVAL' ORDER BY ? ? OFFSET ? ROWS FETCH NEXT ? ROWS ONLY") /*stmt, err := dbconn.Prepare("SELECT requestnumber, requeststatus, NVL(requestor, 'N/A'), NVL(pendingwith, 'N/A'), NVL(processtype, 'N/A'), actiondate FROM requests WHERE requeststatus = 'PENDINGAPPROVAL' ORDER BY requestnumber DESC OFFSET 0 ROWS FETCH NEXT 10 ROWS ONLY")*/ if err != nil { logger.Error("Error while building prepared statement for retrieving dashboard active records", slog.String("Error", err.Error())) return activerecords, err } rows, err := stmt.Query(sortby, sortorder, startindex, pagesize) //rows, err := stmt.Query() if err != nil { logger.Error("Error while executing prepared statement for retrieving dashboard active records", slog.String("Error", err.Error())) return activerecords, err } defer rows.Close() for rows.Next() { var rec datamodel.ActiveRequestRecord err = rows.Scan(&rec.RequestNumber, &rec.RequestStatus, &rec.RequestorName, &rec.PendingWith, &rec.ProcessType, &rec.LastActionDate) if err != nil { logger.Error("Error while processing database resultset for dashboard active records", slog.String("Error", err.Error())) return activerecords, err } activerecords = append(activerecords, rec) } return activerecords, err } </code>
请求表结构:
<code>CREATE TABLE "REQUESTS" ( "REQUESTNUMBER" VARCHAR2(64 CHAR) NOT NULL ENABLE, "REQUESTSTATUS" VARCHAR2(128 CHAR) NOT NULL ENABLE, "SUBMISSIONDATE" TIMESTAMP(6), "PROCESSTYPE" VARCHAR2(256 CHAR), "SUBMITTER" VARCHAR2(256 CHAR) NOT NULL ENABLE, "REQUESTOR" VARCHAR2(512 CHAR), "PENDINGWITH" VARCHAR2(512 CHAR), "ACTIONDATE" TIMESTAMP(6), "RESUBMISSIONDATE" TIMESTAMP(6), PRIMARY KEY ( "REQUESTNUMBER" ), FOREIGN KEY ( "SUBMITTER" ) REFERENCES "SUBMITTERS" ( "USERNAME" ) ) </code>
错误:
time=2023-10-04T06:43:06.304Z level=INFO source=C:/code/tutorials/myapp/internal/storage/dashboard.go:19 msg="Verify values" sortby=requestnumber sortorder=DESC startindex=0 pagesize=10 time=2023-10-04T06:43:06.603Z level=ERROR source=C:/code/tutorials/myapp/internal/storage/dashboard.go:34 msg="Error while executing prepared statement for retrieving dashboard active records" Error="ORA-00911: invalid character\n"
解决方法
直接的问题是您正在使用 JDBC 样式的 ?
绑定占位符,而不是预期的 :var
形式。从 go-ora
包的文档中,您说您正在使用:< /p>
所以你的 stmt
应该是:
SELECT requestnumber, requeststatus, NVL(requestor, 'N/A'), NVL(pendingwith, 'N/A'), NVL(processtype, 'N/A'), actiondate FROM requests WHERE requeststatus = 'PENDINGAPPROVAL' ORDER BY :sortby :sortorder OFFSET :startindex ROWS FETCH NEXT :pagesize ROWS ONLY
但是除了变量之外你不能绑定任何东西,所以它根本不允许你将 sortorder
作为变量,如果你只是删除它并执行以下操作:
ORDER BY :sortby OFFSET :startindex ROWS FETCH NEXT :pagesize ROWS ONLY
这似乎可以工作,但即使这样也不能完全达到您想要的效果,因为排序将按文字列名称而不是它的值进行排序;因此它将作为 ORDER BY 'requestnumber'
的等效项运行,而不是 ORDER BY requestnumber
。并且按该常量字符串排序不会实现任何目标。
您需要在语句中嵌入订购标准:
"... ORDER BY " + sortby + " " + sortorder + " OFFSET :startindex ROWS FETCH NEXT :pagesize ROWS ONLY"
db<>fiddle 使用 PL/SQL 动态游标作为简化的等效项,显示三个版本 - 一个错误,一个没有按预期订购,最后订购正常。
但是您还需要清理这些输入以再次防止 SQL 注入。
以上是如何解决 Golang 中的错误'ORA-00911:无效字符”?的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

在 SQL Server 中使用 SQL 语句创建表的方法:打开 SQL Server Management Studio 并连接到数据库服务器。选择要创建表的数据库。输入 CREATE TABLE 语句,指定表名、列名、数据类型和约束。单击执行按钮创建表。

本文介绍了一种使用 SQL 语句连接三个表的详细教程,指导读者逐步了解如何有效地关联不同表中的数据。通过示例和详细的语法讲解,本文将帮助您掌握 SQL 中表的连接技术,从而能够高效地从数据库中检索关联信息。

phpMyAdmin 可用于在 PHP 项目中创建数据库。具体步骤如下:登录 phpMyAdmin,点击“新建”按钮。输入要创建的数据库的名称,注意符合 MySQL 命名规则。设置字符集,如 UTF-8,以避免乱码问题。

判断 SQL 注入的方法包括:检测可疑输入、查看原始 SQL 语句、使用检测工具、查看数据库日志和进行渗透测试。检测到注入后,采取措施修补漏洞、验证补丁、定期监控、提高开发人员意识。

检查 SQL 语句的方法有:语法检查:使用 SQL 编辑器或 IDE。逻辑检查:验证表名、列名、条件和数据类型。性能检查:使用 EXPLAIN 或 ANALYZE,检查索引并优化查询。其他检查:检查变量、权限和测试查询。

PostgreSQL 添加列的方法为使用 ALTER TABLE 命令并考虑以下细节:数据类型:选择适合新列存储数据的类型,如 INT 或 VARCHAR。默认值:通过 DEFAULT 关键字指定新列的默认值,避免值为 NULL。约束条件:根据需要添加 NOT NULL、UNIQUE 或 CHECK 约束条件。并发操作:使用事务或其他并发控制机制处理添加列时的锁冲突。

MySQL 有免费的社区版和收费的企业版。社区版可免费使用和修改,但支持有限,适合稳定性要求不高、技术能力强的应用。企业版提供全面商业支持,适合需要稳定可靠、高性能数据库且愿意为支持买单的应用。选择版本时考虑的因素包括应用关键性、预算和技术技能。没有完美的选项,只有最合适的方案,需根据具体情况谨慎选择。
