1、表 1-1 用户信息表(siteUser)字段名称 说明 数据类型 字段长度是否允许空约束userID 编号 Nvarchar2 4 否 主键userName 姓名 Nvarchar2 8 否password 密码 Nvarchar2 8 是isAdmin 是否管理员number 1 否 取值是 0 或 1,默认0表 1-2 专辑表(Album)字段名称 说明 数据类型 字段长度 是否允许空 约束albumID 专辑编号 Nvarchar2 4 否 主键albumName 专辑名称 Nvarchar2 20 否albumIntro 专辑简介 Nvarchar2 2000 是issueDate
2、发行时间 date 是 singerID 歌手编号 Nvarchar2 4 否languageID 语言编号 Nvarchar2 4 否classifyID 分类编号 Nvarchar2 4 否表 1-3 歌手表(Singer )字段名称 说明 数据类型 字段长度是否允许空约束singerID 歌手编号 Nvarchar2 4 否 主键singerName 姓名 Nvarchar2 20 否isGroup 是否组合 number 1 否 取值是 0 或 1,默认 0sex 性别 number 1 是 检查约束(男,女)表 1-4 语言表(Language)字段名称 说明 数据类型 字段长度是否
3、允许空约束languageID 语言编号 Nvarchar2 4 否 主键languageName 语言名称 Nvarchar2 20 否表 1-5 专辑分类表(albumClassify)字段名称 说明 数据类型 字段长度是否允许空约束classifyID 分类编号 Nvarchar2 4 否 主键classifyName 分类名称 Nvarchar2 20 否表 1-6 歌曲表(Song)字段名称 说明 数据类型 字段长度是否允许空约束songID 歌曲编号 Nvarchar2 4 否 主键songName 歌曲名称 Nvarchar2 20 否singerID 歌手编号 Nvarchar
4、2 4 否votes 人气值 number 1 否 默认值 0songFile 歌曲文件 blob 否1.创建数据库表 1)创建 siteUser(用户信息表) Create table siteUser(userID Nvarchar2(4) constraint pk_siteUser primary key,userName Nvarchar2(20) not null,Password Nvarchar2(8),isAdmin number(1) default 0 check(isAdmin in(0,1);2)创建 Album(专辑表)Create table Album(albu
5、mID Nvarchar2(4) constraint pk_Album primary key,albumName Nvarchar2(20) not null,albumIntro Nvarchar2(2000) ,issueDate date,singerID Nvarchar2(4) not null,languageID Nvarchar2(4) not null,classifyID Nvarchar2(4) not null);3)创建表 Singer(歌手表)Create table Singer(singerID Nvarchar2(4) constraint pk_Sing
6、er primary key,singerName Nvarchar2(20) not null,isGroup number(1) default 0 check(isGroup in(0,1)sex nchar(1);4)创建 Language 表(语言表)Create table Language(languageID Nvarchar2(4) constraint pk_Language primary key,languageName Nvarchar2(20) not null);5)创建 albumClassify 表(专辑分类表)Create table albumClassi
7、fy(classifyID Nvarchar2(4) constraint pk_albumClassify primary key,classifyName Nvarchar2(20) not null);6)创建表 Song(歌曲表)Create table Song(songID Nvarchar2(4) constraint pk_Song primary key,songName Nvarchar2(20) not null,singerID Nvarchar2(4) not null,votes number(1) default 0,songFile blob);2.创建约束1)
8、创建表 singer 的检查约束 signer_chk1:Alter table signer add constraint singer_chk1 check(sex in(男,女);2)创建表 album 的外键约束 Abbum_singer_fk1:Alter table album add constraint Abbum_signer_fk1 foreign key(singerID) reference signer(singerID);3)创建表 album 的外键约束 Abbum_language_fk1:Alter table album add constraint Abb
9、um_language_fk1 foreign key(languageID) references language(languageID);4)创建表 album 的外键约束 Abbum_classify_fk1:Alter table album add constraint Abbum_classify_fk1 foreign key(classifyID) references Ablumclassify(classifyID);5)创建表 Song 的外键约束 Song_Singer_fk1:Alter table Song add constraint Song_Singer_f
10、k1 foreign key(singerID) references Singer(singerID);3.创建视图1)创建视图 V_album 用以显示专辑信息Create or replace view v_albumAsSelect t1.albumID,t1.albumName,t1.albumIntro,t1.issueDate,t4.singerName,t3.languageName,t2.classifyNameFrom album t1 inner jion albumclassify t2 on t1.classifyID=t2.classifyIDInner jion
11、language t3 on t1.languageID=t3.languageIDINNER JOIN singer t4 on t1.singerID=t4.singerID;2)显示歌曲信息Create or replace view v_songAsSelect t1.songID,t1.songName,t2.singerName,t1.votes,t1.songFileFrom song t1 inner join singer t2 on t1.singerID=t2.singerID;4.创建存储过程1)向专辑表(album)中插入数据的存储过程Create or replac
12、e procedure sp_insertAlbum(AlbumID NVARCHAR2,albumName NVARCHAR2,albumIntro NVARCHAR2,isssueDate DATE,SingerID NVARCHAR2,languageID NVARCHAR2,classifyID NVARCHAR2)ASBEGINInsert into album values(AlbumID,albumName,albumIntro,issueDate,singerID,languageID,classifyID);END sp_insertAlbum;2)修改专辑表数据的存储过程C
13、reate or replace procedure sp_updateAlbum(fAlbumID NVARCHAR2,falbumName NVARCHAR2,falbumIntro NVARCHAR2,fisssueDate DATE,fSingerID NVARCHAR2,flanguageID NVARCHAR2,fclassifyID NVARCHAR2)ASBEGINUpdate album sett AlbumID=fAlbumID,albumName=falbumName ,albumIntro=falbumIntro,issueDate=fisssueDate,singer
14、ID=fSingerID,LanguageID=flanguageID,ClassifyIDfclassifyID;END sp_updateAlbum;3)创建删除专辑表数据的存储过程Create or replace procedure sp_deleteAlbum(fAlbumID NVARCHAR2)AsBeginDelete from album where albumID=falbumID;END sp_deletefalbum;ConnectionFactory 类:Package cn.edu.hbsi.db;Import java.io.IOException;Import
15、java.io.InputStream;Import java.sql.Connection;Import java.sql.DriverManager;Import java.sql.SQLException;Import java.util.Properties;/获得数据库连接Public class ConnectionFactory/数据库驱动类名Private static String DRIVER=” ”;/连接数据库的 URLPrivate static String URL=” ”;/连接数据库的用户名Private static String USERNAME=” ”;/
16、连接数据库的密码Private static String PASSWORD=” ”;Private ConnectionFactoryStatic getPropertiesInfo();/该方法用来获得属性文件中的 driver,url,username,passwordPrivate static getPropertiesInfo()Properties prop=new Properties();InputStream inStream=Thread.currentThread().getContextClassLoader().getResourseAsStream(“jdbcCo
17、n.properties”);Try/获得相应的键值对Prop.load(inStream);Catch(IOException e)e.printStaticTrace();/根据相应的键获得对应的值DRIVER=prop.getProperty(“driver”);URL=prop.getProperty(“url”);USERNAME=prop.getProperty(“username”);PASSWORD=prop.getProperty(“password”);/该方法用来加载驱动,并会的数据库的连接对象 return 数据库连接对象connPublic static Connec
18、tion getConnection()Connection conn=null;Try /加载驱动程序Class.forName(DRIVER);catch(ClassNotFoundExcepyion e)e.printStaticTrace();Try/获得数据库连接的对象Conn=DriverManager.getConnection(URL.USERNAME,PASSWORD);Catch(SQLException e)e.printStaticTrace();Return conn; DbClose 类:Pacage cn.edu.hbsi.db;Import java.sql.C
19、onnection;Import java.sql.Result;Import java.sql.SQLExcwption;Import java.sql.Statement;Public class DbClosePublic static void close(Connection conn)If(null!=conn)TryConn.close();Catch(SQLException e)e.printStaticTrace();Public static void close(Statement stmt)If(null!=stmt)Trystmt.close();Catch(SQL
20、Exception e)e.printStaticTrace();Public static void close(ResultSet rs)If(null!=rs)Tryrs.close();Catch(SQLException e)e.printStaticTrace();Public static void close (ResultSet rs,Statement stmt,Connection conn)Close(rs);Close(stmt,conn);Public static void close (Statement stmt,Connection conn)Close(s
21、tmt);Close(conn);核心模块的实现:1)在 Calbum 类中编写 insertAlbum 方法,调用 ORACLE 数据库中的存储过程SP_INSERTALBUM 实现插入数据操作:Public void insertAlbum(String ALBUMID,String ALBUMNAME,String ALBUMINTRO,DATE ISSUEDATE,String SINGERID)Connection con=null;CallableStatement cs=null;ResultSet rs=null;TryCon=ConnectionFactory.getConn
22、ection();String sql=”call SP_INSERTALBUM(?,?,?,?,?,?,?)”;cs=con.prepareCall(aql);cs.setString(1,ALBUMID);cs.setString(2,ALBUMNAME);cs.setString(3,ALBUMINTRO);cs.setString(4,ISSUEDATE);cs.setString(5,SINGERID);cs.setString(6,LANGUAGEID);cs.setString(7,CLASSIFYID);Cs.execute();Catch(Excepyion e)e.printStaticTrace();FinallyDbclose.close(rs,cs,conn);