簡易代碼之家

            BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
            157 Posts :: 2 Stories :: 57 Comments :: 0 Trackbacks
          Java web程序中備份oracle數(shù)據(jù)庫

          1.生成備份文件:

          public ActionForward createDmp(ActionMapping mapping, ActionForm form,
                      HttpServletRequest request, HttpServletResponse response)
                      
          throws Exception {
                  Calendar c 
          = Calendar.getInstance();
                  SimpleDateFormat sdf 
          = new SimpleDateFormat("yyyyMMddHHmmss");
                  String fileName 
          = "data_oracle" + sdf.format(c.getTime());
                  String dmpFolder 
          = request.getSession().getServletContext()
                          .getRealPath(
          "")
                          
          + "\\datas\\dmp\\";
                  String logFolder 
          = request.getSession().getServletContext()
                          .getRealPath(
          "")
                          
          + "\\datas\\log\\";

                  String cmd 
          = "exp username/password@orcl file='" + dmpFolder + fileName
                          
          + ".dmp' log='" + logFolder + fileName + ".log' owner=username";
                  Runtime.getRuntime().exec(cmd);
                  Thread.sleep(
          100 * 1000);
                  request.setAttribute(
          "msg""備份成功,文件生成會有延遲,請稍等");
                  
          return mapping.findForward("dmpCreated");
              }

          2.查詢備份文件:

          public ActionForward findDmp(ActionMapping mapping, ActionForm form,
                      HttpServletRequest request, HttpServletResponse response)
                      
          throws Exception {
                  String dmpFolder 
          = request.getSession().getServletContext()
                          .getRealPath(
          "")
                          
          + "\\datas\\dmp\\";
                  File folder 
          = new File(dmpFolder);
                  File[] files 
          = folder.listFiles();
                  List
          <String[]> fileList = new ArrayList<String[]>();
                  
          for (int i = 0; i < files.length; i++{
                      
          if (files[i].getName().indexOf(".dmp"> 0{
                          String[] one 
          = new String[2];
                          one[
          0= files[i].getName();
                          one[
          1= files[i].length() / 1000 + "K";
                          fileList.add(one);
                      }

                  }

                  request.setAttribute(
          "fileList", fileList);
                  
          return mapping.findForward("dmpList");
              }

          3.刪除備份文件:

          public ActionForward deleteDmp(ActionMapping mapping, ActionForm form,
                      HttpServletRequest request, HttpServletResponse response)
                      
          throws Exception {
                  String dmpFolder 
          = request.getSession().getServletContext()
                          .getRealPath(
          "")
                          
          + "\\datas\\dmp\\";
                  File folder 
          = new File(dmpFolder);
                  File[] files 
          = folder.listFiles();
                  String fileName 
          = request.getParameter("dmpName");
                  
          for (int i = 0; i < files.length; i++{
                      
          if (files[i].getName().equals(fileName)) {
                          files[i].delete();
                          request.setAttribute(
          "msg""刪除成功");
                          
          break;
                      }

                  }

                  
          return mapping.findForward("dmpList");
              }

          posted on 2010-06-08 18:27 Jakin.zhou 閱讀(1104) 評論(1)  編輯  收藏

          Feedback

          # re: Java web程序中備份oracle數(shù)據(jù)庫 2015-01-21 20:43 yanwushu
          要是寫上如何恢復(fù)數(shù)據(jù)庫就更好了  回復(fù)  更多評論
            


          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 邯郸县| 晋州市| 广汉市| 英德市| 蒙自县| 嫩江县| 韶山市| 白水县| 河北省| 仙桃市| 庆云县| 洛南县| 金沙县| 西华县| 巴马| 千阳县| 咸丰县| 修武县| 于都县| 庐江县| 杭州市| 西乌珠穆沁旗| 利津县| 丹东市| 龙州县| 包头市| 綦江县| 西城区| 保靖县| 焉耆| 义乌市| 凯里市| 巴楚县| 海伦市| 罗源县| 沂水县| 潮安县| 五华县| 安阳县| 万州区| 来安县|