【易客吧】_全网激活码总代_激活码商城

您现在的位置是:首页 > 热门资讯 > 正文

热门资讯

了解 ORA-00972 错误的根源:深入识别标识符长度限制 (了解oracle数据库)

用户投稿2024-04-15热门资讯21

Oracle 数据库中的 ORA-00972 错误表明标识符(例如表、列或视图的名称)的长度超过了允许限制。本文将深入探讨此错误的根源,并指导您解决标识符长度问题。

标识符长度限制

Oracle 数据库对标识符长度施加了限制,以确保数据库的稳定性和一致性。这些限制因 Oracle 版本和所使用的字符集而异。对于 AL32UTF8 字符集(最常见的字符集),标识符的最大长度为 30 个字符。

  • 表和视图名称:30 个字符
  • 列名称,建议使用兼容标识符生成器。这些工具可以帮助您生成满足长度限制和 Oracle 命名约定要求的标识符。

    最佳实践

    为了防止 ORA-00972 错误并确保良好的数据库设计,请遵循以下最佳实践:

    • 使用描述性且简短的名称
    • 避免使用特殊字符或空格
    • 使用大写字母或下划线来分隔单词
    • 使用兼容标识符生成器
    了解 ORA-00972 错误的根源:深入识别标识符长度限制 (了解oracle数据库) 第1张

    结论

    理解 ORA-00972 错误的原因对于维护高效且可扩展的 Oracle 数据库至关重要。通过遵守标识符长度限制和遵循最佳实践,您可以避免此错误并确保您的数据库顺利运行。


有谁知道oracle用户名最大长度支持多少

为30个字符,如果超过长度,数据库库返回错误值如下:SQL 错误: ORA-: 标识符过长. - identifier is too long*Cause: An identifier with more than 30 characters was specified.*Action: Specify at most 30 characters.

SQLPLUS能连接oracle10g,PLSQL也能连,但网页程序却报错ORA-12154: TNS: 无法解析指定的连接标识符

1.检查注册表,HKey_LocalMachineSoftwareOracle下面的Oracle_Home,若不对,修改成正确的;2.卸载ODP for (或者卸载ODT for , ODT中包含ODP, ODT 是的一个集成插件,用于连接和浏览oracle数据库,并且提供对oracle数据库的拖拽操作,类似对于SQL Server的资源管理器);3.如果ODT for 的目录依然存在,删除或者重命名此目录;然后重起系统,重新连接程序,如果还有同样的错误,看着办吧,我建议重装Oracle吧。 分析原因:系统原来装的是ORACLE 10G 10.1.0,卸载后还没重启就装上10.2.0,结果先是监听器起不来,竟然还是指向10.1.0的位置,监听器当然不能启动了。 处理过程:1、查找注册表,将监听器指向新的位置,重启服务,OK;2、PL/SQL DEVELOPER还是连接不了,其它方式都正常。 将原先安装在其它逻辑盘的ODP for 卸载重装到与ORACLE 10.2.0同一位置。 重启系统,DEVELOPER还是报错,不过些时报错提示信息为空。 3、因为DEVELOPER设置有更改后,进入菜单TOOLS》PREFERENCES...设置,在ORACLE下的CONNECTION中,将ORACLE HOME和OCI LIBIARY设为空即自动检测。 连接正常,问题解决。 二、应用程序中报错:一个很难想到的引起ORA-的原因使用时(我连的是Oracle 9i,其他版本未知),如果你的执行目录太长或者有括号等(未考察有些什么符号),那么即使你的服务名是对的,也会引起ORA-问题“TNS: 无法处理服务名”,当出现这个问题时,请也考虑这个原因。 B.进行适当的配置如何正确配置文件:可以在客户端机器上使用oracle Net Configuration Assistant或oracle Net Manager图形配置工具对客户端进行配置,该配置工具实际上修改文件。 所以我们可以直接修改文件,下面以直接修改文件为例:该文件的位置为: … (for windows)…/network/admin/ (for unix)此处,假设服务器名为testserver,服务名为,使用的侦听端口为1521,则文件中的一个test网络服务名(数据库别名)为:test =(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=testserver)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=)))此处的笑脸为)。 红色的内容为需要根据实际情况修改的内容,现解释如下:PROTOCOL:客户端与服务器端通讯的协议,一般为TCP,该内容一般不用改。 HOST:数据库侦听所在的机器的机器名或IP地址,数据库侦听一般与数据库在同一个机器上,所以当我说数据库侦听所在的机器一般也是指数据库所在的机 器。 在UNIX或WINDOWS下,可以通过在数据库侦听所在的机器的命令提示符下使用hostname命令得到机器名,或通过ipconfig(for WINDOWS) or ifconfig(for UNIX)命令得到IP地址。 需要注意的是,不管用机器名或IP地址,在客户端一定要用ping命令ping通数据库侦听所在的机器的机器名,否则需要在 hosts文件中加入数据库侦听所在的机器的机器名的解析。 PORT:数据库侦听正在侦听的端口,可以察看服务器端的文件或在数据库侦听所在的机器的命令提示符下通过lnsrctl status [listener name]命令察看。 此处Port的值一定要与数据库侦听正在侦听的端口一样。 SERVICE_NAME:在服务器端,用system用户登陆后,sqlplus> show parameter service_name命令察看。 如何利用配置的网络服务名连接到数据库:用sqlplus程序通过test网络服务名进行测试,如sqlplus system/manager@test。 如果不能连接到数据库,则在文件中的test网络服务名(net service)后面加上文件中_DOMAIN参数的值,此处我的参数值为,将其加到网络服务名后面,修改后的中关于该网络服务名的内容为:什么情况下会引起oracle自动设置_DOMAIN参数?出现这种情况的典型环境为windows的客户端的‘我得电脑à属性à计算机名à更改à其它…à此计算机的主DNS后缀’中设置了‘primary dns suffix’,因为在这种情况下安装客户端时,会在文件中自动设置_DOMAIN参数,或许当把计算机加入域中安装oracle客户端时也会出现这种情况,有条件的话大家可以试一下。 我在设置oracle的客户端时一般手工修改文件,但是还有许多人喜欢用图形工具配置,该图形工具最终还是修改文件,但是它有时会引起其它的问题:在用oracle的图形配置软件net assistant或‘Net Configuration Assistant’配置网络服务名时,假如已经设置了‘primary dns suffix’,但是在图形配置软件中写的网络服务名的名字中没有‘primary dns suffix’,如只是写了test,则图形配置软件会自动在后面加上‘primary dns suffix’,使之变为,并存在中,而不管你的文件中是否有 _DOMAIN参数。 此时,用图形工具进行测试连接是通过的,但是假如此时文件中没有 _DOMAIN参数,则你在使用网络服务名时应该使用在中的 ,而不是你在图形配置软件中键入的test。 解决的办法为:<1>可以在文件中设置_DOMAIN= ,这时你可以用test或连接数据库<2>在文件中不设置_DOMAIN参数,在文件中将中的去掉,这时你可以用test连接数据库。 关于为什们在网络服务名后面加db_domain参数,需要了解sql*plus连接数据库的原理,我在后面解决常见故障中给出了详细的说明。 如果上面的招数还不奏效的话,只好用一下乾坤大挪移了。 将客户端的网络服务名部分 =(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=testserver)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=)))此处的笑脸为)。 拷贝到服务器的文件中。 然后再服务器端用sqlplus system/连接到数据库。 如果能连接成功,说明你的客户端与服务器端的网络有问题。 如果连接不成功,用前面的部分检查网络服务名部分部分是否正确,如果确信网络服务名部分正确而且所有的客户端都连不上数据库则可能为系统TCP/IP或Oracle系统有问题,建议重新安装数据库。 常见故障解决办法:TNS- (ORA-):TNS:could not resolve service name该错误表示用于连接的网络服务名在文件中不存在,如上面的中的网络服务名只有test,假如用户在连接时用sqlplus system/manager@test1则就会给出TNS-错误。 要注意的是,有时即使在文件中有相应的网络服务名,可是用该网络服务名连接时还会出错,出现这种情况的典型配置如下(在客户端的机器上)文件_PATH = (TNSNAMES, ….)_DOMAIN = 文件:test =(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=testserver)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=)))此处的笑脸为)。 sql*plus运行基本机理:在用户输入sqlplus system/manager@test后,sqlplus程序会自动到文件中找_DOMAIN参数,假 如该参数存在,则将该参数中的值取出,加到网络服务名的后面,即此例中你的输入由sqlplus system/manager@test自动变为sqlplus system/ ,然后再到文件中找网络服务名,这当然找不到了,因为该文件中只有test网络服务名,所以报 错。 解决的办法就是将文件中的_DOMAIN参数注释掉即可,如 #_DOMAIN = 。 假如_DOMAIN参数不存在,则sqlplus程序会直接到文件中找 test网络服务名,然后取出其中的host,port,tcp,service_name,利用这些信息将连接请求发送到正确的数据库服务器上。 另外原则上中的配置不区分大小写,但是我的确遇到区分大小写的情况,所以最好将使用的网络服务与中配置的完全一样。 ORA-: TNS:listener could not resolve SERVICE_NAME given in connect Descriptor.该错误表示能在中找到网络服务名,但是在中指定的SERVICE_NAME与服务器端的SERVICE_NAME不一致。 解决的办法是修改中的SERVICE_NAME。 易混淆术语介绍:Db_name:对一个数据库(Oracle database)的唯一标识,该数据库为第一章讲到的Oracle database。 这种表示对于单个数据库是足够的,但是随着由多个数据库构成的分布式数据库的普及,这种命令数据库的方法给数据库的管理造成一定的负 担,因为各个数据库的名字可能一样,造成管理上的混乱。 为了解决这种情况,引入了Db_domain参数,这样在数据库的标识是由Db_name和 Db_domain两个参数共同决定的,避免了因为数据库重名而造成管理上的混乱。 这类似于互连网上的机器名的管理。 我们将Db_name和 Db_domain两个参数用’.’连接起来,表示一个数据库,并将该数据库的名称称为Global_name,即它扩展了Db_name。 Db_name参数只能由字母、数字、’_’、’#’、’$’组成,而且最多8个字符。 Db_domain:定义一个数据库所在的域,该域的命名同互联网的’域’没有任何关系,只是数据库管理员为了更好的管理分布式数据库而根据实际情况决定的。 当然为了管理方便,可以将其等于互联网的域。 Global_name:对一个数据库(Oracle database)的唯一标识,oracle建议用此种方法命令数据库。 该值是在创建数据库是决定的,缺省值为Db_name. Db_domain。 在以后对参数文件中Db_name与Db_domain参数的任何修改不影响Global_name的值,如果要修改Global_name,只能用ALTER DATABASE RENAME GLOBAL_NAME TO <db__domain>命令进行修改,然后修改相应参数。 Service_name:该参数是oracle8i新引进的。 在8i以前,我们用SID来表示标识数据库的一个实例,但是在Oracle的并行环境中, 一个数据库对应多个实例,这样就需要多个网络服务名,设置繁琐。 为了方便并行环境中的设置,引进了Service_name参数,该参数对应一个数据库, 而不是一个实例,而且该参数有许多其它的好处。 该参数的缺省值为Db_name. Db_domain,即等于Global_name。 一个数据库可以对应多个Service_name,以便实现更灵活的配置。 该参数与SID没有直接关 系,即不必Service name 必须与SID一样。 Net service name:网络服务名,又可以称为数据库别名(database alias)。 是客户端程序访问数据库时所需要,屏蔽了客户端如何连接到服务器端的细节,实现了数据库的位置透明的特性。 看完本文后的感觉:顶一下 踩一下 返回服务器首页【文章内容投诉】【论坛】【收藏此页】【关闭】【客服投诉热线】

C#连接oracle数据库报“ORA-12154: TNS: 无法解析指定的连接标识符”错误看清楚内容再说哦!!

string constring = data source=BILLOW;user=sfcfa;password=sfcfa;;修改为:string constring = Data Source=BILLOW;Persist Security Info=True;User ID=sfcfa;Password=sfcfa看看行不行?我本机可以跑的配置是上面这样写的。 如果不行。 你可以尝试一下, 开始 -->运行cmdD:\>tnsping BILLOW然后观察一下, 会提示:已使用的参数文件:D:\oracle\......\注意观察一下, 这个D:\oracle\......\路径, 是不是你那里的那个所在的路径。 (假如机器上面安装了多个 不同版本的 Oracle 的时候, 会有这个问题)

若对本页面资源感兴趣,请点击下方或右方图片,注册登录后

搜索本页相关的【资源名】【软件名】【功能词】或有关的关键词,即可找到您想要的资源

如有其他疑问,请咨询右下角【在线客服】,谢谢支持!

了解 ORA-00972 错误的根源:深入识别标识符长度限制 (了解oracle数据库) 第2张

发表评论

评论列表

  • 这篇文章还没有收到评论,赶紧来抢沙发吧~
你上次访问网站的时间为:24-05-17,12:23:54 你第11访问网站的时间为:24-05-17 12:23:58