永发信息网

oracle创建一存储过程怎么做

答案:1  悬赏:60  手机版
解决时间 2021-03-04 04:42
oracle创建一存储过程怎么做
最佳答案
数据类型转换
  3.1 异构数据源数据类型概述
  对不同数据库系统,每个DBMS都定义了一套自己的数据类型,但不论数据类型在各个系统中如何变化,其功能都满足用户的数据处理基本要求,如数值型,包括整型、实型、浮点型、双精度型等;字符型,包括定长、变长等;日期型,包括年、月、日和小时、分、秒等;长字符型,包括文本类型,还有钱币型等。随着数据库系统的不断发展和版本的不断升级,数据类型的种类也不断增多,如超文本和二进制处理多媒体和大文本的数据类型。这些带有共性的东西,给系统间的数据转换带来了可能和方便,但不同的数据库的数据类型也是有差异的。其自身定义和扩充之间的区别,也给系统间的数据转换带来了许多困难。例如,DBMS返回的日期和时间数据格式在各个DBMS中有很大的不同。有些系统以8字节整数格式返回日期和时间,另外一些以浮点数格式返回。并且有的DBMS含有LONG类型,其它DBMS无此类型。所以异种数据库数据类型转换的关键是找出其中的对应关系。
    3.2 数据类型转换方法一(设计类型映射表)
  为了实现相互数据转换,必须设计多个相应的双向数据转换程序并且解决不同的数据类型匹配问题。当增加一个数据库系统时,相应要解决该数据库系统与已存在的多个异构库的数据类型匹配问题,并增加多个对应转换程序。为了实现程序的扩展性,可以通过设计类型映射表来解决类型转换问题。
  将不同数据库系统数据类型的对应关系和相应的数据转换处理程序分离开,使数据转换程序相对独立,而把类型转换关系在专门的表结构中存储。通过对不同数据库系统之间的数据类型进行详细而深入的分析,找出了不同数据库系统不同版本的各个不同类型之间缺省的类型对应关系及可能存在的对应关系,将这些数据预先存入类型映射表中。
    3.3 数据类型转换方法二(利用ODBC SQL类型)
  存储在数据源中的数据都有一个数据类型,称为数据源数据类型或SQL数据类型。SQL数据类型是按照SQL-92标准由每一个DBMS定义,可以是某个数据源特有的。驱动程序在ODBC SQL语法及驱动程序数据类型中也定义了一套数据类型称为ODBC SQL数据类型(以SQL前缀开头的数据类型)。每个驱动程序负责映射特定数据来源的SQL数据类型到ODBC SQL数据类型标识符。因此,不同的数据源在进行数据转换的过程中可以通过ODBC SQL数据类型标识符作为基准来得到数据类型的缺省映射关系。驱动程序通过函数SQLGetTypelnfo返回数据源的SQL数据类型和ODBC SQL数据类型的映射关系,在函数SQLCo1Attributes,SQLDescribeCol和 SQLDescribeParm中,驱动程序还用ODBC SQL数据类型来描述列和参数的数据类型。
  此外,ODBC还提供一套以SQL_C前缀开头的ODBC C数据类型。ODBC C数据类型指出了在应用程序中用于存储数据的C缓冲区的数据类型。所有驱动程序必须支持所有的C数据类型,而且支持所有C类型到相应的SQL类型的转换,并且所有的驱动程序至少支持字符SQL类型,使得DBMS的数据类型都能映射到一种C语言的数据类型,这样在传递过程中不会改变数据。每一个SQL数据类型与一个ODBC C数据类型相适应。在从数据源返回数据之前,驱动程序将它转换到指定的C数据类型。在发送数据到数据来源之前,驱动程序将它从指定C数据类型转换到SQL数据类型。
    4 数据转换过程中大对象的处理
  4.1 大对象类型概述
  大对象类型BLOB全称为Binary Large Objects,即二进制大对象。可以把BLOB区别为三种形式:声像数据、二进制数据和大文本数据。因此,最常见的应用就是存储图形、声音等对象,此外大二进制对象、OLE对象也可以通过BLOB类型存入数据库,如果文本对象过大,超出了文本类型的规定长度,则必须用BLOB字段进行存储。我们在经常使用的编程环境中并不能直接支持BLOB字段,因此需要调用相应的函数完成BLOB的使用。
  不同的数据库系统对大对象类型的支持不同,常用数据库系统支持的大对象数据类型如表4所示:    表4数据库系统支持的大对象数据类型
  数据库系统 大对象类型
  SQL SERVER sql_variant,ntext,image,varbinary,binary,text
  ORACLE BLOB,LONG RAW,BFILE,RAW,CLOB,LONG
  SYBASE LONG VARCHAR
  VFP MEMO
  ACCESS OLE OBJECT,MEMO
  KINGBASE blob,text,bytea,varbinary,binary,text    4.2 大对象的存取方法
  1)利用MFC提供的CLongBinary类
  VC存取大对象数据有众多方法,如OLE、ActiveX等,而VC的MFC提供的CLongBinary类可以方便地实现存取BLOB字段。使用CLongBinary类可以存取超过MAXINT数目的数据,最大为可以得到的内存容量。但数据完全保存在内存中,对超大量数据消耗太大。
  2)利用ODBC的SQLGetData和SQLPutData函数
  对于不能存储在单一缓冲区中的数据,在行中的其他数据已被获取之后,可以直接用SQLGetData分批从驱动程序检索这些数据。为了从一列检索长数据,应用程序首先调用SQLFetchScroll或SQLFetch移动一行,并且调用SQLGetData获取绑定列的数据。SQLPutData允许在应用程序语句执行时,把参数或字段送到驱动程序。
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
陕西有几个5A级景区?分别是什么?
汇票付款人承诺在汇票到期日支付汇票金额并签
沃特咨询怎么去啊,有知道地址的么
公共烟道止逆阀有万居五防排气阀那种的吗?
翔升GTX650+ 金刚版 2G D5和七彩虹iGame650
美佳园艺地址有知道的么?有点事想过去
存在的问题反义词是什么
魔兽世界,MOP模型修改区是不是没了?
江韬汽车美容装饰洗车坊地址有知道的么?有点
会唱歌的男生对女生有多大吸引力?
柞树屋场地址有知道的么?有点事想过去
三精牌葡萄糖口服液的小瓶子收集起来能DIY什
詹记私房菜地址在哪,我要去那里办事
帮忙对这个女生打下分(0-10)
买车贷款6万1年还清每个月还多少
推荐资讯
一路上有你第二季人员都有那些?
若要如何全靠自己什么意思
バリ カエリなきこと 是什么意思
罪恶王冠的漫画版的作者是谁?
用什么软件可以查绩点
黑心 火 雨伞彩虹打一成语
观察《讲经图》,所讲内容最有可能是A《诗》
身份证在自动售票机上买不了票怎么办
我最恨的男人,我老婆都会当他是知心朋友
芭诺客冰淇淋工厂这个地址在什么地方,我要处
奔跑吧兄弟座驾,跑男团私底下都开什么车
反转异响,什么原因?
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?