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 中的查询文本是不是有最大长度?的主要内容,如果未能解决你的问题,请参考以下文章