资源描述:
《多媒体数据库设计实验最新版本》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、指标等级ABCD功能完整程序质量按时检查提问回答检查时间总评成绩云南大学软件学院实验报告序号:45实验老师:赵娜课程名称:多媒体数据库系统设计实验名称:OracleMultimedia2学号:20091120261姓名:郭娟课程名称多媒体数据库设计 实验项目实验八实验目的1熟悉Oracle数据库的使用。2.能用基本的SQL语句完成数据表的查询、修改操作。3.根据实验要求完成以下实验任务。实验内容(算法、程序、步骤和方法)实验任务:1.配置PL/SQL环境,设置PL/SQL环境(详见OracleMultimediaUser'sGuideBook11gR2的第41页2.2.1
2、SettingUpYourEnvironmentforPL/SQL)CREATEDIRECTORYMEDIA_DIRAS'c:oracleproduct10.2.0db_1demoschemaproduct_media';2.设置用户(以SCOTT为例)对媒体数据目录的访问权限:(详见OracleMultimediaUser'sGuideBook11gR2的第41页2.2.1SettingUpYourEnvironmentforPL/SQL)GRANTWRITEONDIRECTORYMEDIA_DIRTOSCOTT;GRANTREADONDIRECTORYM
3、EDIA_DIRTOSCOTT;3.PL/SQL的多媒体下载(详见OracleMultimediaUser'sGuideBook11gR2的第42页2.2.3MediaDownloadinPL/SQL)DECLAREimgORDImage;ctxRAW(64):=NULL;BEGINSELECTproduct_photoINTOimgFROMpm.online_mediaWHEREproduct_id=3117;img.export(ctx,'FILE','MEDIA_DIR','3117.jpg');END;/4.PL/SQL的多媒体上传(详见OracleMultime
4、diaUser'sGuideBook11gR2的第42页MediaUploadinPL/SQL)DECLAREimgORDImage;audORDAudio;vidORDVideo;精选范本,供参考!ctxRAW(64):=NULL;18BEGIN‐‐Insertanewrowintothepm.online_mediatable.DELETEFROMpm.online_mediaWHEREproduct_id=3003;INSERTINTOpm.online_media(product_id,product_photo,product_audio,product_vid
5、eo)VALUES(3003,ORDImage.init('FILE','MEDIA_DIR','laptop.jpg'),ORDAudio.init('FILE','MEDIA_DIR','laptop.mpa'),ORDVideo.init('FILE','MEDIA_DIR','laptop.rm'))RETURNINGproduct_photo,product_audio,product_videoINTOimg,aud,vid;‐‐Bringthemediaintothedatabaseandpopulatetheattributes.img.import(ct
6、x);‐‐ORDImage.importalsocallsORDImage.setProperties.aud.import(ctx);aud.setProperties(ctx);vid.import(ctx);vid.setProperties(ctx);‐‐Updatethetablewiththepropertieswehaveextracted.UPDATEpm.online_mediaSETproduct_photo=img,product_audio=aud,product_video=vidWHEREproduct_id=3003;COMMIT;END;/
7、实验步骤:Example1新建连接,在查询窗口中输入命令语句,初次运行后会弹出一个窗口提示:已存在该名称。此时可以将MEDIA_DIR改成MEDIA_DIR1,运行后在左边的目录中就会出现MEDIA_DIR1文件。Example31申明一个图片对象;2从数据表pm.online_media中选择product_id=3117列的product_photo属性,插入到img对象中。Example41申明一个图片对象ORDImage,音频对象ORDAudio,视频对象ORDVideo,二进制文件RAW(64):=NULL;2从数据