java.sql.SQLSyntaxErrorException: ORA-00972: 标识符过长

问题:在使用oracle数据库的时候,提示java.sql.SQLSyntaxErrorException: ORA-00972: 标识符过长怎么解决?

错误原因:

1.Oracle 12c 及之前的版本中,默认的字符集是单字节字符集(如 US7ASCII),此时表名和列名的最大长度是 30 个字节。

2.在 Oracle 12c 及之后的版本中,表名和列名的最大长度是 128 个字符(而不是 30 个字符)。请注意,这个限制是基于字符数而不是字节数。因此,在 Oracle 12c 及之后的版本中,您可以使用最多 128 个字符来命名表和列。

所有你现在要要先判断你的oracle版本是12c之前的还是之后的。

解决办法:

1.先检查对应的数据库中的数据表的名称还有数据字段的名称长度是否超过了30个字符 ,如果超过了就重新换一个单词来命名,实体类中的对应的字段也要改,注意不要超过30个字符的长度。

2. (如果第一步没有问题,或者该了字段名和表名仍然存在问题)检查实体类中对应的字段(属性名/类名)的长度是否超过了30个字符,如果超过了就重新命名 注意新的变量名 不要超过30个字符的长度,使用到这个变量名的地方都替换成最新的变量名。 这样我们在来发送请求就不会有这个错误了!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值