首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL在运行select查询时出错

SQL在运行select查询时出错
EN

Stack Overflow用户
提问于 2021-06-10 15:23:18
回答 1查看 32关注 0票数 0

我运行了这个查询:

代码语言:javascript
复制
Select * from users where user_id=20;

并得到了这个错误:

代码语言:javascript
复制
ORA-00997: illegal use of LONG datatype
00997. 00000 -  "illegal use of LONG datatype"
*Cause:    
*Action:
Error at Line: 6 Column: 37

我想知道为什么会发生这种情况,以及对此的正确查询。

EN

回答 1

Stack Overflow用户

发布于 2021-06-10 15:35:59

您已经将带有user_idcreated your table定义为long数据类型。与C/Java/等不同,long不是数值类型in Oracle

LONG列存储最多包含2 to 1或231-1字节的可变长度字符串。LONG列具有VARCHAR2列的许多特征。您可以使用LONG列来存储长文本字符串。

当Oracle试图隐式地将字符串值转换为数字以便与数字20进行比较时,您会得到错误。虽然这可以用于varchar2列,但long数据类型有很多限制-甚至不应该用于长字符串,它应该是CLOB。

如果您的列包含数值,则将其should be declarednumber,对于ID列,可能将其设置为number(38)以使其成为整数。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67916535

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档