热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Oracle中Long类型的使用与不可使用

ORA-01754表只能包含一个LONG类型的列altertable表名add字段名longraw错误原因:数据表中同时建立了LONGRAW类型和LONG类型。------

ORA-01754 表只能包含一个LONG类型的列
alter table 表名 add 字段名 long raw
错误原因:数据表中同时建立了LONG RAW类型和LONG类型。
--------------------------------------------------------------------------------------------------
一、可以在以下情况使用long字段:
1、 select的list列表。
SQL> insert into test_long values (1,‘tgfdsfgdsgfsd‘);
已创建 1 行。
SQL> insert into test_long values (2,‘asfafafasd‘);
已创建 1 行。
SQL> commit;
提交完成。
SQL> col id for 9999;
SQL> col description for a30;
SQL> select * from test_long;
ID DESCRIPTION
----- ------------------------------
1 tgfdsfgdsgfsd
2 asfafafasd
2、 update语句中的set子句:
SQL> update test_long
2 set description=‘hsy‘
3 where id=2;
已更新 1 行。
SQL> commit;
提交完成。
SQL> select * from test_long;
ID DESCRIPTION
----- ------------------------------
1 tgfdsfgdsgfsd
2 hsy
3、 insert语句中的values子句中。
SQL> insert into test_long values (1,‘tgfdsfgdsgfsd‘);
已创建 1 行。
二、 限制使用long型字段的情况:
1、 一个表中只能使用一个long型字段。
SQL> alter table test_long add (description1 long);
alter table test_long add (description1 long)
*
ERROR 位于第 1 行:
ORA-01754: 表只能包含一个 LONG 类型的列
2、 使用long属性来定义对象type。
SQL> Create type test_list as object(str1 varchar2(50),str2 long);
2 /
警告: 创建的类型带有编译错误。
SQL> Create type test_list as object(str1 varchar2(50),str2 number(5)) ;
2 /
类型已创建。
3、 Long字段不能出现在where子句中和完整性约束中。【除了null和not null约束】。
4、 Long字段不能用来indexed。
5、 存储函数不能用来返回long值。
6、 在plsql程序单元中可以使用long数据类型来定义变量或者参数。但是不能从sql中调用这个程序单元。
7、 在一个单一的sql语句中,所有的long字段,updated tables和locked tables必须位于同一个数据库。
8、 Long和long raw不能用在分布式sql语句中,不能复制。
9、如果表中同时有long和lob字段,在同一个sql语句中long和lob字段不能bind超过4000字节的数据。然而可以单独bind超多4000字节在只有long或者lob字段时。
10、 拥有long字段的表不能位于assm【自动段管理表空间】中。
三、 long字段不能出现在sql语句的部分位置:
1、 含有group by 、order by、connect by、distinct关键字的select语句中。
2、 带有unique操作的select语句。
3、 Create cluster语句的字段列表中。
4、 Create materialized view语句的cluster子句中。
5、 在function、expressions或contitions的内嵌sql中。
6、 含有group by子句的select列表查询中。
7、 含有union、intersect、minus的查询或者子查询中。
8、 Create table …as select语句的select 列表中。
9、 Alter table…move 语句中。
10、 Insert语句的子查询select 列表中。
四、 触发器可以用以下方式使用long字段:
1、 一个sql语句内部的trigger可以插入一个long字段。
2、 如果long字段的数据可以转换为constrained 数据类型(比如char和varchar2),此时可以引用在带有trigger的sql语句。
3、 触发器中的变量不能使用long定义。
4、 new和:old不能使用long字段。
总之:使用long字段的限制很多,使用情况很少,再加上oracle后期版本支持没有提高,所以强烈建议使用lob型来代替long型字段。

Oracle中Long类型的使用与不可使用,,

Oracle中Long类型的使用与不可使用


推荐阅读
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 后台获取视图对应的字符串
    1.帮助类后台获取视图对应的字符串publicclassViewHelper{将View输出为字符串(注:不会执行对应的ac ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 本文详细介绍了在ASP.NET中获取插入记录的ID的几种方法,包括使用SCOPE_IDENTITY()和IDENT_CURRENT()函数,以及通过ExecuteReader方法执行SQL语句获取ID的步骤。同时,还提供了使用这些方法的示例代码和注意事项。对于需要获取表中最后一个插入操作所产生的ID或马上使用刚插入的新记录ID的开发者来说,本文提供了一些有用的技巧和建议。 ... [详细]
author-avatar
Bd专业8楼nv
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有