2009年3月22日

          10g的數(shù)據(jù)庫導成9i的

          ORACLE EXP-00003: 未找到段 (4,131) 的存儲定義
          用oracle9i的客戶端連接10g的數(shù)據(jù)庫,然后執(zhí)行以下腳本。
           

          在導出前, 連接到SYS用戶, 運行以下SQL: 
          CREATE OR REPLACE VIEW exu9tne ( 
          tsno, fileno, blockno, length) AS 
          SELECT ts#, segfile#, segblock#, length 
          FROM sys.uet$ 
          WHERE ext# = 1 
          UNION ALL 
          SELECT * FROM SYS.EXU9TNEB 
          導出完成后,再復原這個view(定義可以通過user_views看到) 對于oracle9i和oracle10g這個定義都相同: 
          CREATE OR REPLACE VIEW exu9tne ( 
          tsno, fileno, blockno, length) AS 
          SELECT ts#, segfile#, segblock#, length 
          FROM sys.uet$ 
          WHERE ext# = 1 
          posted @ 2010-12-01 16:30 Bom Wu 閱讀(479) | 評論 (0)編輯 收藏
           
          存:
          ps.setCharacterStream(4new StringReader("String""String".length());
          ?。?br />
          rs.getString("clob");

          jdk 1.6以后
          可以使用
          Clob clob=connetion.createClob();
          Writer wr
          =clob.setCharacterStream(0);
          //對wr寫入信息
          ps.setClob(clob);
          posted @ 2010-10-14 16:09 Bom Wu 閱讀(330) | 評論 (0)編輯 收藏
           

          inux操作系統(tǒng)定時任務系統(tǒng) Cron 入門


            cron是一個linux下 的定時執(zhí)行工具 ,可以在無需人工干預的情況下運行作業(yè)。由于Cron 是Linux 的內置 服務,但它不自動起來,可以用以下的方法 啟動、關閉 這個服務:

            /sbin/service crond start //啟動服務

            /sbin/service crond stop //關閉服務

            /sbin/service crond restart //重啟服務

            /sbin/service crond reload //重新載入配置

            你也可以將這個服務在系統(tǒng)啟動的時候自動啟動:

            在/etc /rc.d/rc.local 這個腳本的末尾加上:

            /sbin/service crond start

            現(xiàn)在C ron這個服務已經在進程里面了,我們就可以用這個服務了,Cron服務提供以下幾種接口供大家使用:

            1.直接用crontab 命令編輯

            cron服務提供crontab命令來設定cron服務的,以下是這個命令的一些參數(shù) 與說明:

            crontab -u //設定某個用戶的cron服務,一般root 用戶在執(zhí)行 這個命令的時候需要此參數(shù)

            crontab -l //列出某個用戶cron服務的詳細內容

            crontab -r //刪除 沒個用戶的cron服務

            crontab -e //編輯某個用戶的cron服務

            比如說root查看自己的cron設置:crontab -u root -l

            再例如,root想刪除fred的cron設置:crontab -u fred -r

            在編輯cron服務時,編輯的內容有一些格式和約定,輸入:crontab -u root -e

            進入vi 編輯模式 ,編輯的內容一定要符合下面的格式:*/1 * * * * ls >> /tmp/ls.tx t

          任務調度的crond常駐命令
          crond 是linux用來定期執(zhí)行程序的命令。當安裝完成操作系統(tǒng)之后,默認便會啟動此任務調度命令。crond命令每分鍾會定期檢查是否有要執(zhí)行的工作,如果有要執(zhí)行的工作便會自動執(zhí)行該工作。

          1、linux任務調度的工作主要分為以下兩類:
              *系統(tǒng)執(zhí)行的工作:系統(tǒng)周期性所要執(zhí)行的工作,如備份系統(tǒng)數(shù)據(jù)、清理緩存
              *個人執(zhí)行的工作:某個用戶定期要做的工作,例如每隔10分鐘檢查郵件服務器是否有新信,這些工作可由每個用戶自行設置。

          2.crontab命令選項:
              -u指定一個用戶,
              -l列出某個用戶的任務計劃,
              -r刪除某個用戶的任務,
              -e編輯某個用戶的任務

          3.cron文件語法:
                    分    小時   日      月      星期     命令
                  0-59  0-23  1-31  1-12    0-6    command    (取值范圍,0表示周日一般一行對應一個任務)

          4.記住幾個特殊符號的含義:
                  "*"代表取值范圍內的數(shù)字,
                  "/"代表"每",
                  "-"代表從某個數(shù)字到某個數(shù)字,
                  ","分開幾個離散的數(shù)字


          一、任務調度設置文件的寫法

                可用crontab -e命令來編輯,編輯的是/var/spool/cron下對應用戶的cron文件,也可以直接修改/etc/crontab文件
          具體格式如下:
                Minute Hour Day Month Dayofweek   command
                分鐘    小時  天    月       天每星期       命令

          每個字段代表的含義如下:
                Minute            每個小時的第幾分鐘執(zhí)行該任務
               Hour               每天的第幾個小時執(zhí)行該任務
               Day                每月的第幾天執(zhí)行該任務
               Month             每年的第幾個月執(zhí)行該任務
               DayOfWeek    每周的第幾天執(zhí)行該任務
               Command       指定要執(zhí)行的程序
                在這些字段里,除了“Command”是每次都必須指定的字段以外,其它字段皆為可選字段,可視需要決定。對于不指定的字段,要用“*”來填補其位置。

          舉例如下:
          5      *       *          *     *    ls             指定每小時的第5分鐘執(zhí)行一次ls命令
          30    5      *          *     *    ls             指定每天的 5:30 執(zhí)行l(wèi)s命令
          30    7      8         *     *     ls             指定每月8號的7:30分執(zhí)行l(wèi)s命令
          30    5      8         6    *     ls             指定每年的6月8日5:30執(zhí)行l(wèi)s命令
          30    6      *          *    0     ls             指定每星期日的6:30執(zhí)行l(wèi)s命令 [ 注:0表示星期天,1表示星期1,以此類推,也可以用英文來表示,sun表示星期天,mon表示星期一等。 ]
          30    3     10,20    *    *     ls    每月10號及20號的3:30執(zhí)行l(wèi)s命令 [注:“,”用來連接多個不連續(xù)的時段 ]
          25    8-11 *           *    *     ls      每天8-11點的第25分鐘執(zhí)行l(wèi)s命令 [注:“-”用來連接連續(xù)的時段 ]
          */15  *       *           *    *     ls          每15分鐘執(zhí)行一次ls命令 [即每個小時的第0 15 30 45 60分鐘執(zhí)行l(wèi)s命令  ]
          30   6     */10        *     *     ls       每個月中,每隔10天6:30執(zhí)行一次ls命令[即每月的1、11、21、31日是的6:30執(zhí)行一次ls命令。  ]
          每天7:50以root 身份執(zhí)行/etc/cron.daily目錄中的所有可執(zhí)行文件
          50   7      *            *     *    root     run-parts     /etc/cron.daily   [ 注:run-parts參數(shù)表示,執(zhí)行后面目錄中的所有可執(zhí)行文件。  ]

          二、新增調度任務

          新增調度任務可用兩種方法:
                  1、在命令行輸入: crontab -e 然后添加相應的任務,wq存盤退出。
                  2、直接編輯/etc/crontab 文件,即vi /etc/crontab,添加相應的任務。

          三、查看調度任務

                  crontab -l //列出當前的所有調度任務
                  crontab -l -u jp   //列出用戶jp的所有調度任務

          四、刪除任務調度工作

                  crontab -r  //刪除所有任務調度工作

          五、任務調度執(zhí)行結果的轉向

               例1:每天5:30執(zhí)行l(wèi)s命令,并把結果輸出到/jp/test文件中
                  30 5 * * * ls >/jp/test 2>&1
               注:2>&1 表示執(zhí)行結果及錯誤信息。


          編輯/etc/crontab 文件配置cron

            cron服務每分鐘不僅要讀一次/var/spool/cron內的所有文件,還需要讀一次/etc/crontab,因此我們配置這個文件也能運用cron服務做一些事情。用crontab配置是針對某個用戶的,而編輯/etc/crontab是針對系統(tǒng)的任務。此文件的文件格式是:

            SHELL=/bin/bash 

            PATH=/sbin:/bin:/usr/sbin:/usr/bin 

            MAILTO=root //如果出現(xiàn)錯誤,或者有數(shù)據(jù)輸出,數(shù)據(jù)作為郵件發(fā)給這個帳號 

            HOME=/ //使用者運行的路徑,這里是根目錄 

            # run-parts 

            01   *   *   *   *     root run-parts /etc/cron.hourly          //每小時執(zhí)行/etc/cron.hourly內的腳本 

            02   4   *   *   *     root run-parts /etc/cron.daily            //每天執(zhí)行/etc/cron.daily內的腳本 

            22   4   *   *   0     root run-parts /etc/cron.weekly        //每星期執(zhí)行/etc/cron.weekly內的腳本 

            42   4   1   *   *     root run-parts /etc/cron.monthly      //每月去執(zhí)行/etc/cron.monthly內的腳本 

            大家注意"run-parts"這個參數(shù)了,如果去掉這個參數(shù)的話,后面就可以寫要運行的某個腳本名,而不是文件夾名了

          例如:        1、在命令行輸入: crontab -e 然后添加相應的任務,wq存盤退出。
                  2、直接編輯/etc/crontab 文件,即vi /etc/crontab,添加相應的任務

          11 2 21 10 * rm -rf /mnt/fb

          posted @ 2009-09-17 11:28 Bom Wu 閱讀(248) | 評論 (0)編輯 收藏
           
           1
           2import java.util.Date;
           3import java.util.Properties;
           4
           5import javax.mail.Authenticator;
           6import javax.mail.Message;
           7import javax.mail.MessagingException;
           8import javax.mail.PasswordAuthentication;
           9import javax.mail.Session;
          10import javax.mail.Transport;
          11import javax.mail.internet.AddressException;
          12import javax.mail.internet.InternetAddress;
          13import javax.mail.internet.MimeMessage;
          14
          15public class EmailUtils {
          16
          17    private static Properties props;
          18
          19    private static Session session;
          20
          21    // 初始化session
          22    static {
          23        props = System.getProperties();
          24        props.put("mail.transport.protocol""stmp");// 設置郵件服務器的協(xié)議
          25        props.put("mail.host""smtp.qq.com");// 設置郵件發(fā)送服務器地址,該地址由郵件服務供應商提供,這里以QQ郵箱為例
          26        props.put("mail.smtp.auth""true");// 設置郵件發(fā)送服務器需要用戶驗證,即需要賬號密碼才能登錄郵箱
          27        session = Session.getInstance(props, new Authenticator() {// 通過配置獲取一個會話,第二個參數(shù)為驗證類
          28                    @Override
          29                    protected PasswordAuthentication getPasswordAuthentication() {
          30                        return new PasswordAuthentication("your email acount",
          31                                "your email password"); // 在這里指定登錄郵件發(fā)送服務器的賬號與密碼
          32                        // QQ郵箱的賬號默認為 QQ號@qq.com 密碼為QQ密碼
          33                    }

          34                }
          );
          35        // session.setDebug(true); //設置是否為Debug模式,如果為Debug模式,將輸出中間信息。
          36    }

          37
          38    /**
          39     * 發(fā)送郵件
          40     * 
          41     * @param emailTo
          42     *            收件人信箱
          43     * @param title
          44     *            主題
          45     * @param msgs
          46     *            內容
          47     */

          48    public static void sendEmail(String emailTo, String title, String msgs) {
          49        System.out.println(msgs);
          50        Message msg = new MimeMessage(session); // 該類封裝了郵件發(fā)送的內容
          51        try {
          52            // 設置發(fā)件人地址,可以是個假的!
          53            msg.setFrom(new InternetAddress("bom1987120@qq.com"));
          54            // 設置收件人
          55            msg.setRecipients(Message.RecipientType.TO, InternetAddress.parse(
          56                    emailTo, false));
          57            // 設置主題
          58            msg.setSubject(title);
          59            // 設置內容
          60            msg.setText(msgs);
          61            // 設置郵件頭
          62            msg.setHeader("X-Mailer""www.dangdang.com");
          63            // 設置發(fā)送時間
          64            msg.setSentDate(new Date());
          65
          66            // 發(fā)送!
          67            Transport.send(msg);
          68
          69            System.out.println("Mail was sent successfully.\n");
          70        }
           catch (AddressException e) {
          71            e.printStackTrace();
          72        }
           catch (MessagingException e) {
          73            e.printStackTrace();
          74        }

          75    }

          76
          77    //測試
          78    public static void main(String[] argv) {
          79        for (int i = 0; i < 1000; i++)
          80            sendEmail("XXXX@qq.com""Java Mail 測試""這是程序自動給你發(fā)的!");
          81    }

          82
          83}
          posted @ 2009-06-13 15:13 Bom Wu 閱讀(689) | 評論 (0)編輯 收藏
           
          首先必須在JSP中聲明這個標簽庫:
          <%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>

          調用方式為:fn:functionName(arg,...)
          比如:${fn:length(aCollection)}
          length是JSTL庫中自帶的函數(shù),除此之外常的還有:

          函數(shù)

          描述

          fn:contains(string, substring)

          如果參數(shù)string中包含參數(shù)substring,返回true

          fn:containsIgnoreCase(string, substring)

          如果參數(shù)string中包含參數(shù)substring(忽略大小寫),返回true

          fn:endsWith(string, suffix)

          如果參數(shù) string 以參數(shù)suffix結尾,返回true

          fn:escapeXml(string)

          將有特殊意義的XML (和HTML)轉換為對應的XML character entity code,并返回

          fn:indexOf(string, substring)

          返回參數(shù)substring在參數(shù)string中第一次出現(xiàn)的位置

          fn:join(array, separator)

          將一個給定的數(shù)組array用給定的間隔符separator串在一起,組成一個新的字符串并返回。

          fn:length(item)

          返回參數(shù)item中包含元素的數(shù)量。參數(shù)Item類型是數(shù)組、collection或者String。如果是String類型,返回值是String中的字符數(shù)。

          fn:replace(string, before, after)

          返回一個String對象。用參數(shù)after字符串替換參數(shù)string中所有出現(xiàn)參數(shù)before字符串的地方,并返回替換后的結果

          fn:split(string, separator)

          返回一個數(shù)組,以參數(shù)separator 為分割符分割參數(shù)string,分割后的每一部分就是數(shù)組的一個元素

          fn:startsWith(string, prefix)

          如果參數(shù)string以參數(shù)prefix開頭,返回true

          fn:substring(string, begin, end)

          返回參數(shù)string部分字符串, 從參數(shù)begin開始到參數(shù)end位置,包括end位置的字符

          fn:substringAfter(string, substring)

          返回參數(shù)substring在參數(shù)string中后面的那一部分字符串

          fn:substringBefore(string, substring)

          返回參數(shù)substring在參數(shù)string中前面的那一部分字符串

          fn:toLowerCase(string)

          將參數(shù)string所有的字符變?yōu)樾?,并將其返?/font>

          fn:toUpperCase(string)

          將參數(shù)string所有的字符變?yōu)榇髮懀⑵浞祷?/font>

          fn:trim(string)

          去除參數(shù)string 首尾的空格,并將其返回

          posted @ 2009-03-22 16:19 Bom Wu 閱讀(4063) | 評論 (0)編輯 收藏
           
          主站蜘蛛池模板: 红原县| 大港区| 宁陕县| 莲花县| 武鸣县| 辽阳市| 若羌县| 聂荣县| 西城区| 烟台市| 珠海市| 纳雍县| 阜新| 巴林右旗| 平凉市| 桦川县| 蚌埠市| 大渡口区| 龙里县| 仁化县| 南召县| 全椒县| 辽阳县| 历史| 墨脱县| 安阳县| 屯留县| 鹤山市| 栾城县| 深圳市| 房产| 常山县| 周至县| 乌兰浩特市| 盘锦市| 永康市| 玉林市| 福海县| 澎湖县| 江西省| 海口市|