问题:在使用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个字符的长度,使用到这个变量名的地方都替换成最新的变量名。 这样我们在来发送请求就不会有这个错误了!