![翻译文献-制作一个oracle实体项目_第1页](http://file.renrendoc.com/FileRoot1/2017-12/6/04cb73eb-2334-4278-91b0-aa6b5e3f36c9/04cb73eb-2334-4278-91b0-aa6b5e3f36c91.gif)
![翻译文献-制作一个oracle实体项目_第2页](http://file.renrendoc.com/FileRoot1/2017-12/6/04cb73eb-2334-4278-91b0-aa6b5e3f36c9/04cb73eb-2334-4278-91b0-aa6b5e3f36c92.gif)
![翻译文献-制作一个oracle实体项目_第3页](http://file.renrendoc.com/FileRoot1/2017-12/6/04cb73eb-2334-4278-91b0-aa6b5e3f36c9/04cb73eb-2334-4278-91b0-aa6b5e3f36c93.gif)
![翻译文献-制作一个oracle实体项目_第4页](http://file.renrendoc.com/FileRoot1/2017-12/6/04cb73eb-2334-4278-91b0-aa6b5e3f36c9/04cb73eb-2334-4278-91b0-aa6b5e3f36c94.gif)
![翻译文献-制作一个oracle实体项目_第5页](http://file.renrendoc.com/FileRoot1/2017-12/6/04cb73eb-2334-4278-91b0-aa6b5e3f36c9/04cb73eb-2334-4278-91b0-aa6b5e3f36c95.gif)
已阅读5页,还剩35页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
外文原文UNDERSTANDINGTHEORADATAINTERFACEONEOFTHECHOICESINMAKINGANORACLEOBJECTANDITSATTRIBUTEDATAAVAILABLETOJAVAAPPLICATIONSISTOCREATEACUSTOMOBJECTCLASSTHATIMPLEMENTSTHEORACLESQLORADATAANDORACLESQLORADATAFACTORYINTERFACESORYOUCANIMPLEMENTORADATAFACTORYINASEPARATECLASSTHEORADATAANDORADATAFACTORYINTERFACESARESUPPLIEDBYORACLEANDARENOTAPARTOFTHEJDBCSTANDARDUNDERSTANDINGORADATAFEATURESTHEORADATAINTERFACEHASTHESEADVANTAGESITRECOGNIZESORACLEEXTENSIONSTOTHEJDBCORADATAUSESORACLESQLDATUMTYPESDIRECTLYITDOESNOTREQUIREATYPEMAPTOSPECIFYTHENAMESOFTHEJAVACUSTOMCLASSESYOUWANTTOCREATEITPROVIDESBETTERPERFORMANCEORADATAWORKSDIRECTLYWITHDATUMTYPES,THEINTERNALFORMATTHEDRIVERUSESTOHOLDORACLEOBJECTSTHEORADATAANDORADATAFACTORYINTERFACESDOTHEFOLLOWINGTHETODATUMMETHODOFTHEORADATACLASSTRANSFORMSTHEDATAINTOANORACLESQLREPRESENTATIONORADATAFACTORYSPECIFIESACREATEMETHODEQUIVALENTTOACONSTRUCTORFORYOURCUSTOMOBJECTCLASSITCREATESANDRETURNSAORADATAINSTANCETHEJDBCDRIVERUSESTHECREATEMETHODTORETURNANINSTANCEOFTHECUSTOMOBJECTCLASSTOYOURJAVAAPPLICATIONORAPPLETITTAKESASINPUTANORACLESQLDATUMOBJECTANDANINTEGERINDICATINGTHECORRESPONDINGSQLTYPECODEASSPECIFIEDINTHEORACLETYPESCLASSORADATAANDORADATAFACTORYHAVETHEFOLLOWINGDEFINITIONSPUBLICINTERFACEORADATADATUMTODATUMORACLECONNECTIONCONNTHROWSSQLEXCEPTIONPUBLICINTERFACEORADATAFACTORYNOTETHEJPUBLISHERUTILITYSUPPORTSTHEGENERATIONOFCLASSESTHATIMPLEMENTTHEORADATAANDORADATAFACTORYINTERFACESSEE“USINGJPUBLISHERTOCREATECUSTOMOBJECTCLASSES“ONPAGE945ORADATACREATEDATUMD,INTSQL_TYPE_CODETHROWSSQLEXCEPTIONWHERECONNREPRESENTSTHECONNECTIONOBJECT,DREPRESENTSANOBJECTOFTYPEORACLESQLDATUM,ANDSQL_TYPE_CODEREPRESENTSTHESQLTYPECODEFROMTHESTANDARDTYPESORORACLETYPESCLASSOFTHEDATUMOBJECTRETRIEVINGANDINSERTINGOBJECTDATATHEJDBCDRIVERSPROVIDETHEFOLLOWINGMETHODSTORETRIEVEANDINSERTOBJECTDATAASINSTANCESOFORADATATORETRIEVEOBJECTDATAUSETHEORACLESPECIFICORACLERESULTSETCLASSGETORADATAMETHODASSUMEANORACLERESULTSETOBJECTORSORSGETORADATAINTCOL_INDEX,ORADATAFACTORYFACTORYTHISMETHODTAKESASINPUTTHECOLUMNINDEXOFTHEDATAINYOURRESULTSET,ANDAORADATAFACTORYINSTANCEFOREXAMPLE,YOUCANIMPLEMENTAGETORAFACTORYMETHODINYOURCUSTOMOBJECTCLASSTOPRODUCETHEORADATAFACTORYINSTANCETOINPUTTOGETORADATATHETYPEMAPISNOTREQUIREDWHENUSINGJAVACLASSESTHATIMPLEMENTORADATAORUSETHESTANDARDGETOBJECTINDEX,MAPMETHODSPECIFIEDBYTHERESULTSETINTERFACETORETRIEVEDATAASINSTANCESOFORADATAINTHISCASE,YOUMUSTHAVEANENTRYINTHETYPEMAPTHATIDENTIFIESTHEFACTORYCLASSTOBEUSEDFORTHEGIVENOBJECTTYPE,ANDITSCORRESPONDINGSQLTYPENAMETOINSERTOBJECTDATAUSETHEORACLESPECIFICORACLEPREPAREDSTATEMENTCLASSSETORADATAMETHODASSUMEANORACLEPREPAREDSTATEMENTOBJECTOPSOPSSETORADATAINTBIND_INDEX,ORADATACUSTOM_OBJTHISMETHODTAKESASINPUTTHEPARAMETERINDEXOFTHEBINDVARIABLEANDTHENAMEOFTHEOBJECTCONTAININGTHEVARIABLEORUSETHESTANDARDSETOBJECTMETHODSPECIFIEDBYTHEPREPAREDSTATEMENTINTERFACEYOUCANALSOUSETHISMETHOD,INITSDIFFERENTFORMS,TOINSERTORADATAINSTANCESWITHOUTREQUIRINGATYPEMAPTHEFOLLOWINGSECTIONSDESCRIBETHEGETORADATAANDSETORADATAMETHODSTOCONTINUETHEEXAMPLEOFANORACLEOBJECTEMPLOYEE,YOUMIGHTHAVESOMETHINGLIKETHEFOLLOWINGINYOURJAVAAPPLICATIONORADATADATUMORSGETORADATA1,EMPLOYEEGETORAFACTORYINTHISEXAMPLE,ORSISANORACLERESULTSET,GETORADATAISAMETHODINTHEORACLERESULTSETCLASSUSEDTORETRIEVEAORADATAOBJECT,ANDTHEEMPLOYEEISINCOLUMN1OFTHERESULTSETTHESTATICEMPLOYEEGETORAFACTORYMETHODWILLRETURNAORADATAFACTORYTOTHEJDBCDRIVERTHEJDBCDRIVERWILLCALLCREATEFROMTHISOBJECT,RETURNINGTOYOURJAVAAPPLICATIONANINSTANCEOFTHEEMPLOYEECLASSPOPULATEDWITHDATAFROMTHERESULTSETREADINGANDWRITINGDATAWITHAORADATAIMPLEMENTATIONTHISSECTIONDESCRIBESHOWTOREADDATAFROMANORACLEOBJECTORWRITEDATATOANORACLEOBJECTIFYOURCORRESPONDINGJAVACLASSIMPLEMENTSORADATAREADINGDATAFROMANORACLEOBJECTUSINGAORADATAIMPLEMENTATIONTHISSECTIONSUMMARIZESTHESTEPSINREADINGDATAFROMANORACLEOBJECTINTOYOURJAVAAPPLICATIONTHESESTEPSAPPLYWHETHERYOUIMPLEMENTORADATAMANUALLYORUSEJPUBLISHERTOPRODUCEYOURCUSTOMOBJECTCLASSESTHESESTEPSASSUMEYOUHAVEALREADYDEFINEDTHEORACLEOBJECTTYPE,CREATEDTHECORRESPONDINGCUSTOMOBJECTCLASSORHADJPUBLISHERCREATEITFORYOU,ANDDEFINEDASTATEMENTOBJECTSTMTNOTESORADATAANDORADATAFACTORYAREDEFINEDASSEPARATEINTERFACESSOTHATDIFFERENTJAVACLASSESCANIMPLEMENTTHEMIFYOUWISHSUCHASANEMPLOYEECLASSANDANEMPLOYEEFACTORYCLASSTOUSETHEORADATAINTERFACE,YOURCUSTOMOBJECTCLASSESMUSTIMPORTORACLESQLORATLEASTORADATA,ORADATAFACTORY,ANDDATUM1QUERYTHEDATABASETOREADTHEORACLEOBJECTINTOARESULTSET,CASTINGTOANORACLERESULTSETORACLERESULTSETORSORACLERESULTSETSTMTEXECUTEQUERY“SELECTEMP_COLFROMPERSONNEL“WHEREPERSONNELISAONECOLUMNTABLETHECOLUMNNAMEISEMP_COLOFTYPEEMPLOYEE_OBJECT2USETHEGETORADATAMETHODOFYOURORACLERESULTSETTOPOPULATEANINSTANCEOFYOURCUSTOMOBJECTCLASSWITHDATAFROMONEROWOFTHERESULTSETTHEGETORADATAMETHODRETURNSANORACLESQLORADATAOBJECT,WHICHYOUCANCASTTOYOURSPECIFICCUSTOMOBJECTCLASSIFORSNEXTEMPLOYEEEMPEMPLOYEEORSGETORADATA1,EMPLOYEEGETORAFACTORYORIFORSNEXTORADATADATUMORSGETORADATA1,EMPLOYEEGETORAFACTORYTHISEXAMPLEASSUMESTHATEMPLOYEEISTHENAMEOFYOURCUSTOMOBJECTCLASSANDORSISTHENAMEOFYOURORACLERESULTSETOBJECTINCASEYOUDONOTWANTTOUSEGETORADATA,THEJDBCDRIVERSLETYOUUSETHEGETOBJECTMETHODOFASTANDARDJDBCRESULTSETTORETRIEVEORADATADATAHOWEVER,YOUMUSTHAVEANENTRYINTHETYPEMAPTHATIDENTIFIESTHEFACTORYCLASSTOBEUSEDFORTHEGIVENOBJECTTYPE,ANDITSCORRESPONDINGSQLTYPENAMEFOREXAMPLE,IFTHESQLTYPENAMEFORYOUROBJECTISEMPLOYEE,THENTHECORRESPONDINGJAVACLASSISEMPLOYEE,WHICHWILLIMPLEMENTORADATATHECORRESPONDINGFACTORYCLASSISEMPLOYEEFACTORY,WHICHWILLIMPLEMENTORADATAFACTORYUSETHISSTATEMENTTODECLARETHEEMPLOYEEFACTORYENTRYFORYOURTYPEMAPMAPPUT“EMPLOYEE“,CLASSFORNAME“EMPLOYEEFACTORY“THENUSETHEFORMOFGETOBJECTWHEREYOUSPECIFYTHEMAPOBJECTEMPLOYEEEMPEMPLOYEERSGETOBJECT1,MAPIFTHECONNECTIONSDEFAULTTYPEMAPALREADYHASANENTRYTHATIDENTIFIESTHEFACTORYCLASSTOBEUSEDFORTHEGIVENOBJECTTYPE,ANDITSCORRESPONDINGSQLTYPENAME,THENYOUCANUSETHISFORMOFGETOBJECTEMPLOYEEEMPEMPLOYEERSGETOBJECT13IFYOUHAVEGETMETHODSINYOURCUSTOMOBJECTCLASS,USETHEMTOREADDATAFROMYOUROBJECTATTRIBUTESINTOJAVAVARIABLESINYOURAPPLICATIONFOREXAMPLE,IFEMPLOYEEHASEMPNAMEOFTYPECHARANDEMPNUMEMPLOYEENUMBEROFTYPENUMBER,PROVIDEAGETEMPNAMEMETHODTHATRETURNSAJAVASTRINGANDAGETEMPNUMMETHODTHATRETURNSANINTEGERTHENINVOKETHEMINYOURJAVAAPPLICATIONASFOLLOWSSTRINGEMPNAMEEMPGETEMPNAMEINTEMPNUMBEREMPGETEMPNUMWRITINGDATATOANORACLEOBJECTUSINGAORADATAIMPLEMENTATIONTHISSECTIONSUMMARIZESTHESTEPSINWRITINGDATATOANORACLEOBJECTFROMYOURJAVAAPPLICATIONTHESESTEPSAPPLYWHETHERYOUIMPLEMENTORADATAMANUALLYORUSEJPUBLISHERTOPRODUCEYOURCUSTOMOBJECTCLASSESTHESESTEPSASSUMEYOUHAVEALREADYDEFINEDTHEORACLEOBJECTTYPEANDCREATEDTHECORRESPONDINGCUSTOMOBJECTCLASSORHADJPUBLISHERCREATEITFORYOU1IFYOUHAVESETMETHODSINYOURCUSTOMOBJECTCLASS,THENUSETHEMTOWRITEDATAFROMJAVAVARIABLESINYOURAPPLICATIONTOATTRIBUTESOFYOURJAVADATATYPEOBJECTEMPSETEMPNAMEEMPNAMEEMPSETEMPNUMEMPNUMBERTHISSTATEMENTUSESTHEEMPOBJECTANDTHEEMPNAMEANDEMPNUMBERVARIABLESDEFINEDIN“READINGDATAFROMANORACLEOBJECTUSINGAORADATAIMPLEMENTATION“ONPAGE9232WRITEANORACLEPREPAREDSTATEMENTTHATUPDATESANORACLEOBJECTINAROWOFADATABASETABLE,ASAPPROPRIATE,USINGTHEDATAPROVIDEDINYOURJAVADATATYPEOBJECTNOTEALTERNATIVELY,YOUCANFETCHDATAINTOACALLABLESTATEMENTOBJECTTHEORACLECALLABLESTATEMENTCLASSALSOHASAGETORADATAMETHODNOTETHETYPEMAPISNOTUSEDWHENYOUAREPERFORMINGDATABASEINSERTANDUPDATEOPERATIONSORACLEPREPAREDSTATEMENTOPSTMTCONNPREPARESTATEMENT“UPDATEPERSONNELSETEMPLOYEEWHEREEMPLOYEEEMPNUM28959THISASSUMESCONNISYOURCONNECTIONOBJECT3USETHESETORADATAMETHODOFTHEORACLEPREPAREDSTATEMENTTOBINDYOURJAVADATATYPEOBJECTTOTHEPREPAREDSTATEMENTOPSTMTSETORADATA1,EMPTHESETORADATAMETHODCALLSTHETODATUMMETHODOFTHECUSTOMOBJECTCLASSINSTANCETORETRIEVEANORACLESQLSTRUCTOBJECTTHATCANBEWRITTENTOTHEDATABASEINTHISSTEPYOUCOULDALSOUSETHESETOBJECTMETHODTOBINDTHEJAVADATATYPEFOREXAMPLEOPSTMTSETOBJECT1,EMPADDITIONALUSESFORORADATATHEORADATAINTERFACEOFFERSFARMOREFLEXIBILITYTHANTHESQLDATAINTERFACETHESQLDATAINTERFACEISDESIGNEDTOLETYOUCUSTOMIZETHEMAPPINGOFONLYORACLEOBJECTTYPESSQLOBJECTTYPESTOJAVATYPESOFYOURCHOICEIMPLEMENTINGTHESQLDATAINTERFACELETSTHEJDBCDRIVERPOPULATEFIELDSOFACUSTOMJAVACLASSINSTANCEFROMTHEORIGINALSQLOBJECTDATA,ANDTHEREVERSE,AFTERPERFORMINGTHEAPPROPRIATECONVERSIONSBETWEENJAVAANDSQLTYPESTHEORADATAINTERFACEGOESBEYONDSUPPORTINGTHECUSTOMIZATIONOFORACLEOBJECTTYPESTOJAVATYPESITLETSYOUPROVIDEAMAPPINGBETWEENJAVAOBJECTTYPESANDANYSQLTYPESUPPORTEDBYTHEORACLESQLPACKAGEITMIGHTBEUSEFULTOPROVIDECUSTOMJAVACLASSESTOWRAPORACLESQLTYPESANDPERHAPSIMPLEMENTCUSTOMIZEDCONVERSIONSORFUNCTIONALITYASWELLTHEFOLLOWINGARESOMEPOSSIBLESCENARIOSTOPERFORMENCRYPTIONANDDECRYPTIONORVALIDATIONOFDATATOPERFORMLOGGINGOFVALUESTHATHAVEBEENREADORAREBEINGWRITTENTOPARSECHARACTERCOLUMNSSUCHASCHARACTERFIELDSCONTAININGURLINFORMATIONINTOSMALLERCOMPONENTSNOTEYOUCANUSEYOURJAVADATATYPEOBJECTSASEITHERINOROUTBINDVARIABLESTOMAPCHARACTERSTRINGSINTONUMERICCONSTANTSTOMAPDATAINTOMOREDESIRABLEJAVAFORMATSSUCHASMAPPINGADATEFIELDTOJAVAUTILDATEFORMATTOCUSTOMIZEDATAREPRESENTATIONFOREXAMPLE,DATAINATABLECOLUMNISINFEETBUTYOUWANTITREPRESENTEDINMETERSAFTERITISSELECTEDTOSERIALIZEANDDESERIALIZEJAVAOBJECTSINTOOROUTOFRAWFIELDS,FOREXAMPLEFOREXAMPLE,USEORADATATOSTOREINSTANCESOFJAVAOBJECTSTHATDONOTCORRESPONDTOAPARTICULARSQLORACLE9OBJECTTYPEINTHEDATABASEINCOLUMNSOFSQLTYPERAWTHECREATEMETHODINORADATAFACTORYWOULDHAVETOIMPLEMENTACONVERSIONFROMANOBJECTOFTYPEORACLESQLRAWTOTHEDESIREDJAVAOBJECTTHETODATUMMETHODINORADATAWOULDHAVETOIMPLEMENTACONVERSIONFROMTHEJAVAOBJECTTOANORACLESQLRAWOBJECTTHISCANBEDONE,FOREXAMPLE,BYUSINGJAVASERIALIZATIONUPONRETRIEVAL,THEJDBCDRIVERTRANSPARENTLYRETRIEVESTHERAWBYTESOFDATAINTHEFORMOFANORACLESQLRAWANDCALLSTHEORADATAFACTORYSCREATEMETHODTOCONVERTTHEORACLESQLRAWOBJECTTOTHEDESIREDJAVACLASSWHENYOUINSERTTHEJAVAOBJECTINTOTHEDATABASE,YOUCANSIMPLYBINDITTOACOLUMNOFTYPERAWTOSTOREITTHEDRIVERTRANSPARENTLYCALLSTHEORADATATODATUMMETHODTOCONVERTTHEJAVAOBJECTTOANORACLESQLRAWOBJECTTHISOBJECTISTHENSTOREDINACOLUMNOFTYPERAWINTHEDATABASESUPPORTFORTHEORADATAINTERFACESISALSOHIGHLYEFFICIENTBECAUSETHECONVERSIONSAREDESIGNEDTOWORKUSINGORACLESQLFORMATS,WHICHHAPPENTOBETHEINTERNALFORMATSUSEDBYTHEJDBCDRIVERSMOREOVER,THETYPEMAP,WHICHISNECESSARYFORTHESQLDATAINTERFACE,ISNOTREQUIREDWHENUSINGJAVACLASSESTHATIMPLEMENTORADATAFORMOREINFORMATIONONWHYCLASSESTHATIMPLEMENTORADATADONOTNEEDATYPEMAP,SEE“UNDERSTANDINGTHEORADATAINTERFACE“ONPAGE921THEDEPRECATEDCUSTOMDATUMINTERFACEASARESULTOFTHEORACLEJDBCINTERFACESBEINGINTRODUCEDINORACLE9IASANALTERNATIVETOTHEORACLEJDBCDRIVERCLASSES,THEORACLESQLCUSTOMDATUMANDORACLESQLCUSTOMDATUMFACTORYINTERFACES,FORMERLYUSEDTOACCESSCUSTOMIZEDOBJECTS,HAVEBEENDEPRECATEDBYTHENEWINTERFACESORACLESQLORADATAANDORACLESQLORADATAFACTORYTHEFOLLOWINGARETHESPECIFICATIONSFORTHECUSTOMDATUMANDCUSTOMDATUMFACTORYINTERFACESPUBLICINTERFACECUSTOMDATUMORACLESQLDATUMTODATUMORACLEJDBCDRIVERORACLECONNECTIONCTHROWSSQLEXCEPTION/THEFOLLOWINGISEXPECTEDTOBEPRESENTINAN/IMPLEMENTATION/DEFINITIONOFPUBLICSTATICFIELDSFOR/_SQL_TYPECODE,_SQL_NAMEAND_SQL_BASETYPE/SEEORACLEJDBCDOCUMENTATIONFORDETAILS/DEFINITIONOF/PUBLICSTATICCUSTOMDATUMFACTORY/GETFACTORY/PUBLICINTERFACECUSTOMDATUMFACTORYORACLESQLCUSTOMDATUMCREATEORACLESQLDATUMD,INTSQLTYPETHROWSSQLEXCEPTIONOBJECTTYPEINHERITANCEOBJECTTYPEINHERITANCEISANORACLE9IFEATUREWHICHALLOWSANEWOBJECTTYPETOBECREATEDBYEXTENDINGANOTHEROBJECTTYPEWHILEORACLE9IDOESNOTYETSUPPORTJDBC30,OBJECTTYPEINHERITANCEISSUPPORTEDANDDOCUMENTEDTHENEWOBJECTTYPEISTHENASUBTYPEOFTHEOBJECTTYPEFROMWHICHITEXTENDSTHESUBTYPEAUTOMATICALLYINHERITSALLTHEATTRIBUTESANDMETHODSDEFINEDINTHESUPERTYPETHESUBTYPECANADDATTRIBUTESANDMETHODS,ANDOVERLOADOROVERRIDEMETHODSINHERITEDFROMTHESUPERTYPEOBJECTTYPEINHERITANCEINTRODUCESSUBSTITUTABILITYSUBSTITUTABILITYISTHEABILITYOFASLOTDECLAREDTOHOLDAVALUEOFTYPETTODOSOINADDITIONTOANYSUBTYPEOFTYPETORACLE9IJDBCDRIVERSHANDLESUBSTITUTABILITYTRANSPARENTLYADATABASEOBJECTISRETURNEDWITHITSMOSTSPECIFICTYPEWITHOUTLOSINGINFORMATIONFOREXAMPLE,IFTHESTUDENT_TOBJECTISSTOREDINAPERSON_TSLOT,THEORACLEJDBCDRIVERRETURNSAJAVAOBJECTTHATREPRESENTSTHESTUDENT_TOBJECTCREATINGSUBTYPESCREATECUSTOMOBJECTCLASSESIFYOUWANTTOHAVEJAVACLASSESTHATEXPLICITLYCORRESPONDTOTHEORACLEOBJECTTYPESSEE“CREATINGANDUSINGCUSTOMOBJECTCLASSESFORORACLEOBJECTS“ONPAGE910IFYOUHAVEAHIERARCHYOFOBJECTTYPES,YOUMAYWANTACORRESPONDINGHIERARCHYOFJAVACLASSESTHEMOSTCOMMONWAYTOCREATEADATABASESUBTYPEINJDBCISTOPASSTHEEXTENDEDSQLCREATETYPECOMMANDTOTHEEXECUTEMETHODOFTHEJAVASQLSTATEMENTINTERFACEFOREXAMPLE,TOCREATEATYPEINHERITANCEHIERARCHYFORPERSON_T|STUDENT_T|PARTTIMESTUDENT_TTHEJDBCCODECANBESTATEMENTSCONNCREATESTATEMENTSEXECUTE“CREATETYPEPERSON_TSSNNUMBER,NAMEVARCHAR230,ADDRESSVARCHAR2255“SEXECUTE“CREATETYPESTUDENT_TUNDERPERSON_TDEPTIDNUMBER,MAJORVARCHAR2100“SEXECUTE“CREATETYPEPARTTIMESTUDENT_TUNDERSTUDENT_TNUMHOURSNUMBER“INTHEFOLLOWINGCODE,THE“FOO“MEMBERPROCEDUREINTYPESTISOVERLOADEDANDTHEMEMBERPROCEDURE“PRINT“OVERWRITESTHECOPYITINHERITSFROMTYPETCREATETYPETASOBJECT,MEMBERPROCEDUREFOOXNUMBER,MEMBERPROCEDUREPRINT,NOTFINALCREATETYPESTUNDERT,MEMBERPROCEDUREFOOXDATE,OVERLOAD“FOO“OVERRIDINGMEMBERPROCEDUREPRINT,OVERRIDE“PRINT“STATICFUNCTIONBARONCETHESUBTYPESHAVEBEENCREATED,THEYCANBEUSEDASBOTHCOLUMNSOFABASETABLEASWELLASATTRIBUTESOFAOBJECTTYPEFORCOMPLETEDETAILSONTHESYNTAXTOCREATESUBTYPES,SEETHEORACLE9IAPPLICATIONDEVELOPERSGUIDEOBJECTRELATIONALFEATURESFORDETAILSIMPLEMENTINGCUSTOMIZEDCLASSESFORSUBTYPESINMOSTCASES,ACUSTOMIZEDJAVACLASSREPRESENTSADATABASEOBJECTTYPEWHENYOUCREATEACUSTOMIZEDJAVACLASSFORASUBTYPE,THEJAVACLASSCANEITHERMIRRORTHEDATABASEOBJECTTYPEHIERARCHYORNOTYOUCANUSEEITHERTHEORADATAORSQLDATASOLUTIONINCREATINGCLASSESTOMAPTOTHEHIERARCHYOFOBJECTTYPESUSEOFORADATAFORTYPEINHERITANCEHIERARCHYCUSTOMIZEDMAPPINGWHEREJAVACLASSESIMPLEMENTTHEORACLESQLORADATAINTERFACEISTHERECOMMENDEDMAPPINGSEE“RELATIVEADVANTAGESOFORADATAVERSUSSQLDATA“ONPAGE911ORADATAMAPPINGREQUIRESTHEJDBCAPPLICATIONTOIMPLEMENTTHEORADATAANDORADATAFACTORYINTERFACESTHECLASSIMPLEMENTINGTHEORADATAFACTORYINTERFACECONTAINSAFACTORYMETHODTHATPRODUCESOBJECTSEACHOBJECTREPRESENTSADATABASEOBJECTTHEHIERARCHYOFTHECLASSIMPLEMENTINGTHEORADATAINTERFACECANMIRRORTHEDATABASEOBJECTTYPEHIERARCHYFOREXAMPLE,THEJAVACLASSESMAPPINGTOPERSON_TANDSTUDENT_TAREASFOLLOWSPERSONJAVAUSINGORADATACODEFORTHEPERSONJAVACLASSWHICHIMPLEMENTSTHEORADATAANDORADATAFACTORYINTERFACESCLASSPERSONIMPLEMENTSORADATA,ORADATAFACTORYSTATICFINALPERSON_PERSONFACTORYNEWPERSONPUBLICNUMBERSSNPUBLICCHARNAMEPUBLICCHARADDRESSPUBLICSTATICORADATAFACTORYGETORADATAFACTORYRETURN_PERSONFACTORYPUBLICPERSONPUBLICPERSONNUMBERSSN,CHARNAME,CHARADDRESSTHISSSNSSNTHISNAMENAMETHISADDRESSADDRESSPUBLICDATUMTODATUMORACLECONNECTIONCTHROWSSQLEXCEPTIONSTRUCTDESCRIPTORSDSTRUCTDESCRIPTORCREATEDESCRIPTOR“SCOTTPERSON_T“,COBJECTATTRIBUTESSSN,NAME,ADDRESSRETURNNEWSTRUCTSD,C,ATTRIBUTESPUBLICORADATACREATEDATUMD,INTSQLTYPETHROWSSQLEXCEPTIONIFDNULLRETURNNULLOBJECTATTRIBUTESSTRUCTDGETORACLEATTRIBUTESRETURNNEWPERSONNUMBERATTRIBUTES0,CHARATTRIBUTES1,CHARATTRIBUTES2STUDENTJAVAEXTENDINGPERSONJAVACODEFORTHESTUDENTJAVACLASSWHICHEXTENDSTHEPERSONJAVACLASSCLASSSTUDENTEXTENDSPERSONSTATICFINALSTUDENT_STUDENTFACTORYNEWSTUDENTPUBLICNUMBERDEPTIDPUBLICCHARMAJORPUBLICSTATICORADATAFACTORYGETORADATAFACTORYRETURN_STUDENTFACTORYPUBLICSTUDENTPUBLICSTUDENTNUMBERSSN,CHARNAME,CHARADDRESS,NUMBERDEPTID,CHARMAJORSUPERSSN,NAME,ADDRESSTHISDEPTIDDEPTIDTHISMAJORMAJORPUBLICDATUMTODATUMORACLECONNECTIONCTHROWSSQLEXCEPTIONSTRUCTDESCRIPTORSDSTRUCTDESCRIPTORCREATEDESCRIPTOR“SCOTTSTUDENT_T“,COBJECTATTRIBUTESSSN,NAME,ADDRESS,DEPTID,MAJORRETURNNEWSTRUCTSD,C,ATTRIBUTESPUBLICCUSTOMDATUMCREATEDATUMD,INTSQLTYPETHROWSSQLEXCEPTIONIFDNULLRETURNNULLOBJECTATTRIBUTESSTRUCTDGETORACLEATTRIBUTESRETURNNEWSTUDENTNUMBERATTRIBUTES0,CHARATTRIBUTES1,CHARATTRIBUTES2,NUMBERATTRIBUTES3,CHARATTRIBUTES4CUSTOMIZEDCLASSESTHATIMPLEMENTTHEORADATAINTERFACEDONOTHAVETOMIRRORTHEDATABASEOBJECTTYPEHIERARCHYFOREXAMPLE,YOUCOULDHAVEDECLAREDTHEABOVECLASS,STUDENT,WITHOUTASUPERCLASSINTHISCASE,STUDENTWOULDCONTAINFIELDSTOHOLDTHEINHERITEDATTRIBUTESFROMPERSON_TASWELLASTHEATTRIBUTESDECLAREDBYSTUDENT_TORADATAFACTORYIMPLEMENTATIONTHEJDBCAPPLICATIONUSESTHEFACTORYCLASSINQUERYINGTHEDATABASETORETURNINSTANCESOFPERSONORITSSUBCLASSES,ASINTHEFOLLOWINGEXAMPLERESULTSETRSETSTMTEXECUTEQUERY“SELECTPERSONFROMTAB1“WHILERSETNEXTOBJECTSRSETGETORADATA1,PERSONFACTORYGETORADATAFACTORYACLASSIMPLEMENTINGTHEORADATAFACTORYINTERFACESHOULDBEABLETOPRODUCEINSTANCESOFTHEASSOCIATEDCUSTOMOBJECTTYPE,ASWELLASINSTANCESOFANYSUBTYPE,ORATLEASTALLTHETYPESYOUEXPECTTOSUPPORTINTHEFOLLOWINGEXAMPLE,THEPERSONFACTORYGETORADATAFACTORYMETHODRETURNSAFACTORYTHATCANHANDLEPERSON_T,STUDENT_T,ANDPARTTIMESTUDENT_TOBJECTSBYRETURNINGPERSON,STUDENT,ORPARTTIMESTUDENTJAVAINSTANCESCLASSPERSONFACTORYIMPLEMENTSORADATAFACTORYSTATICFINALPERSONFACTORY_FACTORYNEWPERSONFACTORYPUBLICSTATICORADATAFACTORYGETORADATAFACTORYRETURN_FACTORYPUBLICORADATACREATEDATUMD,INTSQLTYPETHROWSSQLEXCEPTIONSTRUCTSSTRUCTDIFSGETSQLTYPENAMEEQUALS“SCOTTPERSON_T“RETURNPERSONGETORADATAFACTORYCREATED,SQLTYPEELSEIFSGETSQLTYPENAMEEQUALS“SCOTTSTUDENT_T“RETURNSTUDENTGETORADATAFACTORYCREATED,SQLTYPEELSEIFSGETSQLTYPENAMEEQUALS“SCOTTPARTTIMESTUDENT_T“RETURNPARTTIMESTUDENTGETORADATAFACTORYCREATED,SQLTYPEELSERETURNNULLTHEFOLLOWINGEXAMPLEASSUMESATABLETAB1,SUCHASTHEFOLLOWINGCREATETABLETAB1IDXNUMBER,PERSONPERSON_TINSERTINTOTABL1VALUES1,PERSON_T1000,SCOTT,100ORACLEPARKWAYINSERTINTOTABL1VALUES2,STUDENT_T1001,PETER,200ORACLEPARKWAY,101,CSINSERTINTOTABL1VALUES3,PARTTIMESTUDENT_T1002,DAVID,300ORACLEPARKWAY,102,EEUSEOFSQLDATAFORTYPEINHERITANCEHIERARCHYTHECUSTOMIZEDCLASSESTHATIMPLEMENTTHEJAVASQLSQLDATAINTERFACECANMIRRORTHEDATABASEOBJECTTYPEHIERARCHYTHEREADSQLANDWRITESQLMETHODSOFASUBCLASSCASCADEEACHCALLTOTHECORRESPONDINGMETHODSINTHESUPERCLASSINORDERTOREADORWRITETHESUPERCLASSATTRIBUTESBEFOREREADINGORWRITINGTHESUBCLASSATTRIBUTESFOREXAMPLE,THEJAVACLASSESMAPPINGTOPERSON_TANDSTUDENT_TAREASFOLLOWSPERSONJAVAUSINGSQLDATACODEFORTHEPERSONJAVACLASSWHICHIMPLEMENTSTHESQLDATAINTERFACEIMPORTJAVASQLPUBLICCLASSPERSONIMPLEMENTSSQLDATAPRIVATESTRINGSQL_TYPEPUBLICINTSSNPUBLICSTRINGNAMEPUBLICSTRINGADDRESSPUBLICPERSONPUBLICSTRINGGETSQLTYPENAMETHROWSSQLEXCEPTIONRETURNSQL_TYPEPUBLICVOIDREADSQLSQLINPUTSTREAM,STRINGTYPENAMETHROWSSQLEXCEPTIONSQL_
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 贷款融资居间合同书
- 全新门店店长入股合作协议
- 外墙粉刷承包合同范本
- 家装承包协议
- 硬件采购合同范本
- 餐饮摊位租赁合同
- 汽车维修简单版的合同范本
- 广告牌施工合同
- 精准扶贫家庭无偿房屋租赁合同
- 全新生鲜超市合伙协议
- 《庭院景观设计》课件-15庭院景观设计案例赏析
- 阿拉伯联合酋长国-课件
- 知识产权法(新)-第一次形考任务-国开-参考资料
- 深基坑施工作业风险管控与隐患排查(汇编)
- (2024年)保安培训图文课件
- 工程质量事故赔偿协议书
- 2024年高考语文一轮复习讲练测(新教材新高考)第07讲小说语言类试题(练习)(原卷版+解析)
- 苏州市虎丘区2022-2023学年八年级下学期期末道德与法治试题(含答案和解析)
- 高中数学课件-微课-错位相减法求和
- 学校食堂食品采购询价定价实施方案
- 国家开放大学《JavaScript程序设计》复习指导参考答案
评论
0/150
提交评论