OracleCommand.CommandText 中的查询文本是不是有最大长度?

Posted

技术标签:

【中文标题】OracleCommand.CommandText 中的查询文本是不是有最大长度?【英文标题】:Is there a maximum length for a query text in OracleCommand.CommandText?OracleCommand.CommandText 中的查询文本是否有最大长度? 【发布时间】:2013-03-20 10:52:00 【问题描述】:

我正在使用 OracleCommand 类从 C# 查询 Oracle 数据库(版本 9 或 10)。

String query = GetQuery(); //may produce quite lenghty queries...
OracleCommand command = connection.CreateCommand();
command.CommandText = query;
command.CommandType = CommandType.Text;

此类位于Oracle.DataAccess.dll(版本“10.2.0.100”)中的Oracle.DataAccess.Client 命名空间中,它来自Oracle,而不是Microsoft。据我所知,它已经很老了,但如果没有必要,我不喜欢改变。

我担心的是,这个查询字符串有最大长度吗?该类或底层 Oracle 数据库是否有限制?

注意:我熟悉 Microsoft SQL Server,但对 Oracle 很陌生。 我也确实寻找过文档,但这次谷歌对这个细节没有太大帮助。

【问题讨论】:

在 11g 中,我看到了几千行长的查询(不是我写的 - 写它们的人早已不复存在,但正如莎士比亚所说,“人们所犯的邪恶生活在他们...”)。换句话说——限制(以 11g 为单位)非常大,如果遇到它,您就做错了非常非常大的事情。 【参考方案1】:

Oracle9i Database Reference 声明了 sql 语句长度的限制:

最大 64 K;特定工具可能会施加较低的限制

Similar page on 11g 并没有声明确切的限制:

SQL 语句的长度限制取决于许多因素,包括数据库配置、磁盘空间和内存

我相信我们可以确定 10 和 11 版本的 oracle 数据库支持 64k 查询。

OracleCommand 类的文档不会对 CommandText 长度引入任何异常或限制。

【讨论】:

感谢您帮助我解决这个问题!

以上是关于OracleCommand.CommandText 中的查询文本是不是有最大长度?的主要内容,如果未能解决你的问题,请参考以下文章