數(shù)據(jù)庫課程設計報告-教學管理系統(tǒng)_第1頁
已閱讀1頁,還剩16頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、<p><b>  相關技術簡介</b></p><p><b>  RDBMS簡介</b></p><p>  SQL Server 是一個關系數(shù)據(jù)庫管理系統(tǒng)它最初是由Microsoft Sybase 和Ashton-Tate三家公司共同開發(fā)的于1988 年推出了第一個OS/2 版本在Windows NT 推出后Microsoft與S

2、ybase 在SQL Server 的開發(fā)上就分道揚鑣了Microsoft 將SQL Server 移植到Windows NT 系統(tǒng)上專注于開發(fā)推廣SQL Server 的Windows NT 版本Sybase 則較專注于SQL Server在UNIX 操作系統(tǒng)上的應用在本書中介紹的是Microsoft SQL Server 以后簡稱為SQL Server或MS SQL Server 。</p><p>  SQ

3、L Server 2000 是Microsoft 公司推出的SQL Server 數(shù)據(jù)庫管理系統(tǒng)的最新版本該版本繼承了SQL Server 7.0 版本的優(yōu)點同時又比它增加了許多更先進的功能具有使用方便可伸縮性好與相關軟件集成程度高等優(yōu)點可跨越從運行Microsoft Windows 98 的膝上型電腦到運行Microsoft Windows 2000 的大型多處理器的服務器等多種平臺使用。</p><p>&l

4、t;b>  Eclipse簡介</b></p><p>  Eclipse是一種可擴展的開放源代碼IDE。2001年11月,IBM公司捐出價值4,000萬美元的源代碼組建了Eclipse聯(lián)盟,并由該聯(lián)盟負責這種工具的后續(xù)開發(fā)。集成開發(fā)環(huán)境(IDE)經(jīng)常將其應用范圍限定在“開發(fā)、構建和調試”的周期之中。為了幫助集成開發(fā)環(huán)境(IDE)克服目前的局限性,業(yè)界廠商合作創(chuàng)建了Eclipse平臺。Eclip

5、se允許在同一IDE中集成來自不同供應商的工具,并實現(xiàn)了工具之間的互操作性,從而顯著改變了項目工作流程,使開發(fā)者可以專注在實際的嵌入式目標上。 </p><p>  Eclipse框架的這種靈活性來源于其擴展點。它們是在XML中定義的已知接口,并充當插件的耦合點。擴展點的范圍包括從用在常規(guī)表述過濾器中的簡單字符串,到一個Java類的描述。任何Eclipse插件定義的擴展點都能夠被其它插件使用,反之,任何Eclip

6、se插件也可以遵從其它插件定義的擴展點。除了解由擴展點定義的接口外,插件不知道它們通過擴展點提供的服務將如何被使用。 </p><p>  利用Eclipse,我們可以將高級設計(也許是采用UML)與低級開發(fā)工具(如應用調試器等)結合在一起。如果這些互相補充的獨立工具采用Eclipse擴展點彼此連接,那么當我們用調試器逐一檢查應用時,UML對話框可以突出顯示我們正在關注的器件。事實上,由于Eclipse并不了解開

7、發(fā)語言,所以無論Java語言調試器、C/C++調試器還是匯編調試器都是有效的,并可以在相同的框架內同時瞄準不同的進程或節(jié)點。 </p><p>  Eclipse的最大特點是它能接受由Java開發(fā)者自己編寫的開放源代碼插件,這類似于微軟公司的Visual Studio和Sun 微系統(tǒng)公司的NetBeans平臺。Eclipse為工具開發(fā)商提供了更好的靈活性,使他們能更好地控制自己的軟件技術。Eclipse 聯(lián)盟已經(jīng)

8、宣布將在2004年中期發(fā)布其3.0版軟件。這是一款非常受歡迎的java開發(fā)工具,這國內的用戶越來越多,實際上實用它java開發(fā)人員是最多的。缺點就是較復雜,對初學者來說,理解起來比較困難。</p><p><b>  需求分析</b></p><p><b>  2.1數(shù)據(jù)流圖</b></p><p><b> 

9、 說明:</b></p><p><b>  1、用戶請求包括:</b></p><p>  (1) 學生基本信息管理</p><p><b>  新生信息錄入。</b></p><p>  學生信息修改:按學號查詢出某學生的信息并做信息修改。</p><p>

10、  (2) 系基本信息管理:系的基本信息輸入、修改、刪除</p><p>  (3) 課程信息管理:課程信息的輸入、修改、刪除</p><p>  (4) 教職工信息管理:教職工信息的輸入、修改、刪除</p><p>  (5) 選課管理:</p><p>  每學期所選課程的學分不能超過15分。</p><p&g

11、t;  學生可以同時選修一門或多門課程。 </p><p>  可以同時為多個學生選修某一門或某幾門課程。</p><p>  刪除和修改選課信息。</p><p><b>  (6) 成績管理</b></p><p>  按課程輸入和修改成績。</p><p>  按學生輸入和修改成績。<

12、;/p><p><b>  (7) 信息查詢</b></p><p>  按學號、姓名、系號查詢學生基本信息。</p><p>  按職工號、姓名、系號查詢教職工基本信息。</p><p>  按系號、系名稱查詢系的基本信息。</p><p>  按課程號、課程名稱、上課教師姓名查詢課程基本信息。&

13、lt;/p><p>  按學號、學生姓名、課程號、課程名稱、上課教師姓名、系號查詢學生成績,內容包括課程基本情況。若查詢涉及多門課程,則按課程分組。每門課程按總評成績從高分到低分給出選修該門課程的所有學生的成績(平時成績、考試成績和總評成績)。</p><p><b>  (8) 統(tǒng)計報表</b></p><p>  成績登記表,內容包括課程基本

14、信息(課程號、課程名稱、任課教師號、學時、學分、上課時間、上課地點、考試時間)、選課學生名單(學號、姓名、性別),每個學生的平時成績(空格)、考試成績(空格)和總評成績(空格),按學號排序:</p><p>  順序輸出所有課程的成績登記表。</p><p>  按課程號、課程名稱、教師姓名輸出對應課程的成績登記表。</p><p>  2、以上的用戶請求經(jīng)應用程序

15、的轉化,化為對數(shù)據(jù)庫中的相應的表或視圖的操作,數(shù)據(jù)庫再把處理的結果(或都是錯誤信息)返回結應用程序。</p><p>  3、應用程序把結果返回給用戶,該結果可能為一個對表操作的結果(如插入,刪除等),也可能為一個查詢的結果,甚至可能為一個錯誤的信息。</p><p><b>  2.2數(shù)據(jù)字典</b></p><p>  根據(jù)題目的需求,教學

16、系統(tǒng)主要是對學生,教職工,學院,課程,成績等的管理。由此分析得到如下數(shù)據(jù)結構:</p><p>  數(shù)據(jù)庫的表結構的設計,數(shù)據(jù)項如下,表名分別為:users, score, department, student, teach_job, course:</p><p>  2.3安全性和完整性要求</p><p>  安全性和完整性要求:</

17、p><p>  通過設置外鍵,建立它們之間的關系,并使它們級聯(lián)更新相關的字段,級聯(lián)刪除相關的記錄。對于構成了環(huán)的級聯(lián)更新或刪除,而不能建立級聯(lián)更新或刪除的,通過建立觸發(fā)器,使得它們保持數(shù)據(jù)的完整性。通過不同權限的人登錄而設置其對數(shù)據(jù)的增刪改的權限增強數(shù)據(jù)的安全性。</p><p>  本系統(tǒng)的外鍵設置和級聯(lián)操作有:外鍵:stuent表的depth_id?!ourse表的t_id。</p

18、><p>  score表的stu_id和c_id等。由于score表的兩個鍵若都級聯(lián)操作會構成環(huán),所以級聯(lián)不成功。所以在這里建立兩個觸發(fā)器取代級聯(lián)操作,從而實現(xiàn)數(shù)據(jù)庫的完整性。</p><p><b>  概念結構設計</b></p><p><b>  E-R圖</b></p><p><b&

19、gt;  ER圖</b></p><p><b>  邏輯結構設計</b></p><p><b>  關系模型</b></p><p><b>  關系模型的設計</b></p><p>  學生(學號、姓名、性別、出生日期、入學成績、所在系號、密碼)</p

20、><p>  教師(職工號、姓名、性別、出生年月、所在系號、職稱、專業(yè)及教學方向)</p><p>  系(系號、系名稱、系的簡介)</p><p>  課程(課程號、課程名稱、任課教師號、學時、學分、上課時間、上課地點、考試時間)</p><p>  成績(學號、課程號、平時成績、考試成績、總評成績)</p><p>&

21、lt;b>  擁有(學號、系號)</b></p><p>  屬于(職工號、系號)</p><p>  講授(職工號、課程號、上課時間)</p><p>  選修(學號、課程號、上課時間)</p><p><b>  用戶子模式</b></p><p>  成績視圖(學號、學生姓

22、名、教師號、教師姓名、課程號、上課時間、課程名、</p><p>  平時成績、考試成績、總評成績、)</p><p>  選課視圖(學號、課程號、上課時間、平時成績、考試成績、總評成績、課程名、學時、學分)</p><p>  統(tǒng)計視圖(課程號、上課時間、課程名稱、任課教師號、學時、學分、上課地點、考試時間、學號、學生姓名、學生性別、平時成績、考試成績、總評成績)

23、</p><p><b>  安全性</b></p><p>  安全性的實現(xiàn)主要是通過應用程序來實現(xiàn),在程序中設定一個檢查用戶名和密碼的機構,用戶要進入系統(tǒng)就先要輸入授權了的用戶名和密碼方能進入。</p><p><b>  數(shù)據(jù)庫物理設計</b></p><p><b>  建立索引&

24、lt;/b></p><p>  為各個表的主碼建立索引。</p><p><b>  學生(學號)</b></p><p><b>  教師(職工號)</b></p><p><b>  系(系號)</b></p><p>  課程(課程號、上課

25、時間)</p><p>  成績(學號、課程號)</p><p><b>  數(shù)據(jù)庫存放位置</b></p><p>  數(shù)據(jù)的存儲和數(shù)據(jù)處理</p><p>  在綜合考慮存取時間,存儲空間的利用率,維護的代價3個方面的因素,進行權衡,選擇折中的方案。將易變部分與穩(wěn)定部分、經(jīng)常存取部分和存取頻率較低部分分開存放。<

26、;/p><p><b>  系統(tǒng)配置</b></p><p>  Windows XP</p><p>  MicorSoft SQL Server 2000 (必需升級到SP3)</p><p>  Eclipse開發(fā)環(huán)境</p><p><b>  數(shù)據(jù)庫實施</b><

27、/p><p>  創(chuàng)建數(shù)據(jù)庫及數(shù)據(jù)對象(括號中為對應的SQL腳本文件)</p><p>  創(chuàng)建數(shù)據(jù)庫的對象: create database teach;</p><p><b>  創(chuàng)建表的過程如下:</b></p><p>  create table users(user_name varchar(15) not n

28、ull,</p><p>  password varchar(15),</p><p>  popedom tinyint not null); </p><p>  create table department(depth_id smallint primary key, depth_name char(14),</p><p>  d

29、iscription varchar(50));</p><p>  create table teach_job(t_id int primary key, t_name char(8), sex char(2),</p><p>  birthday smalldatetime,</p><p>  depth_id smallint foreign key r

30、eferences department(depth_id),</p><p>  job char(10), speciality char(16), direction char(16));</p><p>  create table course(c_id smallint primary key, c_name char(16) not null,</p><

31、p>  t_id int foreign key references teach_job(t_id), credit smallint,</p><p>  period smallint, class_time smalldatetime,</p><p>  class_area char(10), exam_time smalldatetime);</p>&l

32、t;p>  create table student(stu_id char(6) primary key, s_name char(8),</p><p>  birthday smalldatetime,  score int,</p><p>  depth_id smallint foreign key references department(depth_id));<

33、;/p><p>  create table score(stu_id char(6), c_id smallint, u_score int, exam_score int,</p><p>  total int,  primary key(stu_id,c_id));</p><p><b>  數(shù)據(jù)備份和恢復方案</b></p>

34、<p>  事務故障的恢復是由系統(tǒng)自動完成的,對用戶透明。系統(tǒng)故障的恢復由系統(tǒng)重新啟動時自動完成,不需要用戶干預。介質故障的恢復則由人干預完成,方法為重裝數(shù)據(jù)庫,然后重做已完成的事務。</p><p>  1、數(shù)據(jù)庫備份方案:</p><p>  <1>每月進行一次數(shù)據(jù)庫的完整備份,包括所有的數(shù)據(jù)及數(shù)據(jù)庫對象。速度較慢,占用大量磁盤空間。應該在整個數(shù)據(jù)庫不進行其他

35、事務操作的時候備份可以提高數(shù)據(jù)備份的速度。</p><p>  <2>每天進行事務日志備份,事務日志備份是指對數(shù)據(jù)庫發(fā)生的事務進行備份,包括上次進行事務日志備份,差異備份和數(shù)據(jù)庫完全備份之后所有已經(jīng)完成的事務。所需的時間和磁盤空間要求較少</p><p>  <3>每小時進行差異備份,是備份一次數(shù)據(jù)備份以來的數(shù)據(jù)變化。</p><p><

36、;b>  恢復解決方案:</b></p><p>  先恢復最近一次的數(shù)據(jù)庫備份,接著進行差異備份的恢復,最后進行事務日志血仇的恢復。</p><p>  用戶界面的設計和實現(xiàn)及相關應用程序編碼</p><p>  本系統(tǒng)的程序代碼結構如下圖所示:主要是四個包:</p><p>  1〉其中中frame包中包含一個layou

37、t包。frame包主要是視圖層的代碼,主界面,登錄界面,各種操作的界面都在其中。此外包含一個包layout,在其中有一個類,用于網(wǎng)格組布局的封裝了網(wǎng)格組布局的一些代碼。在MyAction中封裝的是主窗口里面的所有菜單事件。</p><p>  2〉在model包中主要處理的是模型層,對數(shù)據(jù)的操作封裝其中。</p><p>  3〉query一個類包含了對學生信息的查詢。</p>

38、<p>  4〉此外在util中包含的是對數(shù)據(jù)庫的所有操作。其中有對數(shù)據(jù)庫的更改,把數(shù)據(jù)庫的數(shù)據(jù)和表格模型相關聯(lián)起來的等操作。</p><p><b>  主界面如下所示:</b></p><p>  〈5〉關鍵代碼如下:由于代碼太多,以下只寫出很少的一部分代碼</p><p>  1》對數(shù)據(jù)庫的操作:</p>&l

39、t;p>  public class ConneJdbc {</p><p>  protected static Connection connection = null;</p><p>  private Connection con = null;</p><p>  private ResultSet rs = null;</p>&l

40、t;p>  private ResultSetMetaData rsmd = null;</p><p>  public ConneJdbc() {</p><p><b>  try {</b></p><p>  Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDr

41、iver");</p><p>  connection = DriverManager.getConnection(</p><p>  "jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=teaching ",</p><p>  "sa", "

42、;");</p><p>  } catch (java.lang.ClassNotFoundException classnotfound) {</p><p>  classnotfound.printStackTrace();</p><p>  } catch (java.sql.SQLException sql) {</p><

43、;p>  sql.printStackTrace();</p><p><b>  }</b></p><p><b>  }</b></p><p>  public Connection getCon() {</p><p>  return connection;</p>

44、<p><b>  }</b></p><p>  public Vector selectSql(String sql) {</p><p>  Vector vdata = new Vector();</p><p><b>  try {</b></p><p>  rs = con

45、nection.prepareStatement(sql).executeQuery();</p><p>  rsmd = rs.getMetaData();</p><p>  while (rs.next())</p><p>  vdata.addElement(rs.getObject(1));</p><p>  } catch

46、(SQLException e) {</p><p>  e.printStackTrace();</p><p><b>  }</b></p><p>  return vdata;</p><p><b>  }</b></p><p>  public String

47、selectOne(String sql) {</p><p>  ResultSet rs = null;</p><p>  ResultSetMetaData rsmd = null;</p><p><b>  try {</b></p><p>  rs = connection.prepareStatemen

48、t(sql).executeQuery();</p><p>  rsmd = rs.getMetaData();</p><p>  if (rs.next())</p><p>  return (String)rs.getObject(1);</p><p>  } catch (SQLException e) {</p>

49、<p>  e.printStackTrace();</p><p><b>  }</b></p><p>  return null;</p><p><b>  }</b></p><p>  public boolean inTable(String user, String p

50、a) throws SQLException {</p><p>  Statement stmt = null;</p><p>  PreparedStatement pstmt = null;</p><p>  ResultSet rs = null;</p><p>  String sql = "select passw

51、ord from users " +</p><p>  "where user_name='" + user +"' and password='"</p><p>  + pa + "'";</p><p>  rs = connection.prepareSt

52、atement(sql).executeQuery();</p><p>  if(rs.next())return true;</p><p>  else return false;</p><p><b>  }</b></p><p><b>  }</b></p><p

53、>  2》表格模型的處理:</p><p>  public class SqlTableModel extends DefaultTableModel {</p><p>  private Connection con = null;</p><p>  private ResultSet rs = null;</p><p>  

54、private ResultSetMetaData rsmd = null;</p><p>  public SqlTableModel(String sqlStr, String[] name) {</p><p>  con = new ConneJdbc().getCon();</p><p><b>  try{</b></p&

55、gt;<p>  rs = con.prepareStatement(sqlStr).executeQuery();</p><p>  rsmd = rs.getMetaData();</p><p>  for(int i=0; i<rsmd.getColumnCount(); i++) {</p><p>  addColumn(name[

56、i]);</p><p><b>  }</b></p><p>  while(rs.next()){</p><p>  Vector vdata = new Vector();</p><p>  for ( int i = 1 ; i <= rsmd.getColumnCount() ; i ++){<

57、;/p><p>  vdata.addElement(rs.getObject(i));</p><p><b>  }</b></p><p>  addRow(vdata);</p><p><b>  }</b></p><p>  }catch(java.sql.SQLE

58、xception sql){</p><p>  sql.printStackTrace();</p><p>  }finally {</p><p><b>  try {</b></p><p>  con.close();</p><p>  } catch (SQLException e

59、) {</p><p>  e.printStackTrace();</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  3)Updatabase的一部分代碼:<

60、;/p><p>  public class UpdateDatebase extends ConneJdbc {</p><p>  private Statement stmt = null;</p><p>  private PreparedStatement pstmt = null;</p><p>  private String

61、infoStr = null;</p><p>  private String sql;</p><p>  public UpdateDatebase() {</p><p><b>  }</b></p><p>  public boolean insert(DepData data) throws SQLExc

62、eption {</p><p>  String sql = "insert into department (depth_name,discription) values ('"</p><p>  + data.getDepth_name() + "','" + data.getDiscription() + "

63、;')";</p><p>  pstmt = connection.prepareStatement(sql);</p><p>  pstmt.execute();</p><p>  return true;</p><p><b>  }</b></p><p>  

64、public boolean insert(StuData data) throws SQLException {</p><p>  sql = "insert into student values ('"</p><p>  + data.getStu_id() + "','" + data.getS_name() +

65、"','" </p><p>  + data.getSex() + "','" + data.getBirthday() + "',"</p><p>  + data.getScore() +"," + data.getDepth_id() + ")&quo

66、t;;</p><p>  pstmt = connection.prepareStatement(sql);</p><p>  pstmt.execute();</p><p>  return true;</p><p><b>  }</b></p><p>  public bo

67、olean insert(Teadata data) throws SQLException {</p><p>  sql = "insert into teach_job values ("</p><p>  + data.getT_id() + ",'" + data.getT_name() + "','&q

68、uot; </p><p>  + data.getSex() + "','" + data.getBirthday() + "',"</p><p>  + data.getDepth_id() +",'" + data.getJob() + "','"<

69、/p><p>  +data.getSpeciality() + "','"+ data.getDirection() + "')";</p><p>  pstmt = connection.prepareStatement(sql);</p><p>  pstmt.execute();</p

70、><p>  return true;</p><p><b>  }</b></p><p>  public boolean insert(CourseData data) throws SQLException {</p><p>  sql = "insert into course (c_name,t

71、_id,credit,period,class_time," +</p><p>  "class_area,exam_time) values ("</p><p>  + "'" + data.getC_name() + "'," </p><p>  + data.getT_

72、id() + "," + data.getCredit() + ","</p><p>  + data.getPeriod() +",'" + data.getClass_time() + "','"</p><p>  + data.getClass_area() +"&#

73、39;,'" + data.getExam_time() + "')";</p><p>  pstmt = connection.prepareStatement(sql);</p><p>  pstmt.execute();</p><p>  return true;</p><p&g

74、t;<b>  }</b></p><p>  系統(tǒng)測試方案和測試報告</p><p>  系統(tǒng)的測試:由于測試的數(shù)據(jù)眾多,窗口眾多,就不一一截圖,以下是部分的測試截圖:</p><p>  1)學生管理測試窗口如下:</p><p><b>  2)院系管理測試:</b></p>&

75、lt;p><b>  3)教工管理測試:</b></p><p><b>  4)成績管理:</b></p><p><b>  安裝和使用說明</b></p><p><b>  JDK的安裝</b></p><p>  先雙擊JDK的安裝可執(zhí)行文

76、件,按提示把JDK安裝到指定的目錄下,然后在“控制面板”->“系統(tǒng)”->“高級”->“環(huán)境變量”中新建或修改如下幾個環(huán)境變量:(注意,安裝的JDK的位置不同,設置也不同,只要設為相應的目錄下的相應文件即可)</p><p>  用戶變量中,path變量需要新增值“C:\j2sdk1.6.0\bin;.”</p><p>  系統(tǒng)變量中,CLASSPATH變量需要新增值“C

77、:\j2sdk1.6.0\lib\tools.jar;C:\j2sdk1.6.0\lib\dt.jar”</p><p>  系統(tǒng)變量中,HOME_PATH變量需要設置值“C:\j2sdk1.6.0”.</p><p>  Eclipse的安裝</p><p>  把壓縮包解壓到任意的目錄下即可。</p><p>  數(shù)據(jù)庫的升級與數(shù)據(jù)的導入

78、</p><p>  SQL Sever 2000安裝完成后,請升級到SP3,雙擊chs_sql2ksp3.exe,解壓到任一文件夾,再雙擊setup.bat,即可。數(shù)據(jù)的導入請選用SQL Sever 2000的“附加數(shù)據(jù)庫”功能,在企業(yè)管理器中,選中“數(shù)據(jù)庫”,右鍵,選中“附加數(shù)據(jù)庫”再按提示選出要附加的數(shù)據(jù)庫即可。</p><p><b>  程序的運行</b>&

79、lt;/p><p>  本系統(tǒng)的使用簡單,根據(jù)可視化的界面直接操作。系統(tǒng)的主函數(shù)放在類:EnterFrame中,通過登錄界面的登錄進入MainFrame這個主界面程序。運行EnterFrame,則出來登錄界面如下:</p><p>  本系統(tǒng)的管理員用戶是root,密碼也是root。</p><p>  在程序的運行前,先要導入數(shù)據(jù)庫的JDBC驅動程序的包,在工程文件夾

80、的lib文件夾中有三個包,msbase, mssqlserver, msutil。這樣就可以運行程序了。</p><p><b>  參考文獻</b></p><p><b>  參考資料:</b></p><p>  《Java 核心技術》-第7版</p><p>  《數(shù)據(jù)庫系統(tǒng)概論》-王珊

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論