<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    軟件是對(duì)質(zhì)量的不懈追求

    #

    Linux下mail使用技巧

    登錄LINUX系統(tǒng)后,經(jīng)常會(huì)看到"you have mail",卻苦于不知道如何查看,相信菜鳥們都遇到過,偶在網(wǎng)上用“linux mail"找了很久,但大都是介紹mail服務(wù)器的,黃天總算沒負(fù)有心人,在洪恩在找到一篇介紹基礎(chǔ)的文章,不敢獨(dú)享。
     
    系統(tǒng)提供了用戶 之間通信的郵件系統(tǒng),當(dāng)用戶打開終端注冊(cè)登錄時(shí)發(fā)現(xiàn)系統(tǒng)給出如下信息:
        you have mail.

        這時(shí)用戶可通過鍵入mail命令讀取信件:

        $ mail

        mail程序?qū)⒅饌€(gè)顯示用戶的信件,并依照時(shí)間順序,顯示最新的信件。每顯示一段信件,mail都詢問用戶是否要對(duì)該信件作些處理。若用戶回答d,則表示 刪除信件;若僅按回車鍵,表示對(duì)信件不作任何改動(dòng)(信件仍舊保存,下次還可讀這一信件);若回答p,則要求重復(fù)顯示信件;s filename表示要把信件存入所命名的文件;若回答q,表示要從mail退出。

        我們?cè)诒菊碌牡谝粋€(gè)例子中演示了如何寫一封信,作為練習(xí),你可送信件給自己,然后鍵入mail讀取自己發(fā)的信件,看看會(huì)有什么效果。(發(fā)信給自己是一種設(shè) 置備忘錄的方法)。

        $mail frank 給自己寫信

        subject: test

        This is a mail test

        CRL-d

        EOT

        $

        $mail 查看信件

        “/var/spool/mail/frank:”1 message 1 new

        >Nfrank@xteam.xteamlinux.comThu Mar 25 11:00 13/403 “test”

        &

        Message 1:

        From frank Thu Mar 25 11:00:25 1999/3/25

        Received: (fromfrank@localhost)

        by xteam.xteamlinux.com(8.8.4/8.8.4)

        id LAA05170 for frank;Thu 25 Mar 1999 11:00:25 GMT

        Date: Thu,25 Mar 1999 11:00:25 GMT

        From:RHS Linux User <frank@xteam.xteamlinux.com>

        Message-Id:<199903251142.LAA05170@xteam.xteamlinux.com>

        To:frank@xteam.xteamlinux.com

        Subject:test

        Status:R

        This is a mail test

        &

        mail命令還有很多其它用法,例如發(fā)送事先準(zhǔn)備好的信件,或一次送信給若干人。還可以用其它方法送信件。

    posted @ 2010-06-18 11:05 BlakeSu 閱讀(190) | 評(píng)論 (0)編輯 收藏

    Mysql中l(wèi)imit的用法詳解

        Mysql中l(wèi)imit的用法:在我們使用查詢語句的時(shí)候,經(jīng)常要返回前幾條或者中間某幾行數(shù)據(jù),這個(gè)時(shí)候怎么辦呢?
      不用擔(dān)心,mysql已經(jīng)為我們提供了這樣一個(gè)功能。

      SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset

    LIMIT 子句可以被用于強(qiáng)制 SELECT 語句返回指定的記錄數(shù)。LIMIT 接受一個(gè)或兩個(gè)數(shù)字參數(shù)。參數(shù)必須是一個(gè)整數(shù)常量。
      如果給定兩個(gè)參數(shù),第一個(gè)參數(shù)指定第一個(gè)返回記錄行的偏移量,第二個(gè)參數(shù)指定返回記錄行的最大數(shù)目。初始記錄行的偏移量是 0(而不是 1):
      為了與 PostgreSQL 兼容,MySQL 也支持句法: LIMIT # OFFSET #。

    mysql> SELECT * FROM table LIMIT 5,10; // 檢索記錄行 6-15

    //為了檢索從某一個(gè)偏移量到記錄集的結(jié)束所有的記錄行,可以指定第二個(gè)參數(shù)為 -1:

    mysql> SELECT * FROM table LIMIT 95,-1; // 檢索記錄行 96-last.

    //如果只給定一個(gè)參數(shù),它表示返回最大的記錄行數(shù)目:

    mysql> SELECT * FROM table LIMIT 5; //檢索前 5 個(gè)記錄行

    //換句話說,LIMIT n 等價(jià)于 LIMIT 0,n。

    注意limit 10和limit 9,1的不同:

    例如:

    1.Select * From cyclopedia Where ID>=(
        Select Max(ID) From (
          Select ID From cyclopedia Order By ID limit 90001
        ) As tmp
      ) limit 100;

    2.Select * From cyclopedia Where ID>=(
        Select Max(ID) From (
          Select ID From cyclopedia Order By ID limit 90000,1
        ) As tmp
      ) limit 100;

     

        第1句是先取了前90001條記錄,取其中最大一個(gè)ID值作為起始標(biāo)識(shí),然后利用它可以快速定位下100條記錄

    第2句擇是僅僅取90000條記錄后1條,然后取ID值作起始標(biāo)識(shí)定位下100條記錄

    第1句執(zhí)行結(jié)果.100 rows in set (0.23) sec

    第2句執(zhí)行結(jié)果.100 rows in set (0.19) sec

    其實(shí)第2句完全可以簡(jiǎn)化成:
        Select * From cyclopedia Where ID>=(
       Select ID From cyclopedia limit 90000,1
    )limit 100;

    直接利用第90000條記錄的ID,不用經(jīng)過Max運(yùn)算,這樣做理論上效率因該高一些,但在實(shí)際使用中幾乎看不到效果,
       因?yàn)楸旧矶ㄎ籌D返回的就是1條記錄,Max幾乎不用運(yùn)作就能得到結(jié)果,但這樣寫更清淅明朗,省去了畫蛇那一足.


    Select Top 100 * From cyclopedia Where ID>=(
    Select Top 90001 Max(ID) From (
    Select ID From cyclopedia Order By ID
    ) As tmp
    )

    但不管是實(shí)現(xiàn)方式是存貯過程還是直接代碼中,瓶頸始終在于MS-SQL的TOP總是要返回前N個(gè)記錄,這種情況在數(shù)據(jù)量不大時(shí)感受不深,
       但如果成百上千萬,效率肯定會(huì)低下的.相比之下MySQL的limit就有優(yōu)勢(shì)的多,執(zhí)行:


    Select ID From cyclopedia limit 90000
    Select ID From cyclopedia limit 90000,1

    的結(jié)果分別是:


    90000 rows in set (0.36) sec
    1 row in set (0.06) sec

    而MS-SQL只能用Select Top 90000 ID From cyclopedia 執(zhí)行時(shí)間是390ms,執(zhí)行同樣的操作時(shí)間也不及MySQL的360ms.

    limit的offset(偏移量)用于記錄較多的時(shí)候,記錄較少時(shí),偏移offset較小,直接使用limit較優(yōu)。offset越大,后者越優(yōu)。
     

    1、offset比較小的時(shí)候。

    select * from yanxue8_visit limit 10,10

    多次運(yùn)行,時(shí)間保持在0.0004-0.0005之間


    Select * From yanxue8_visit Where vid >=(
      Select vid From yanxue8_visit Order By vid limit 10,1
    ) limit 10

    多次運(yùn)行,時(shí)間保持在0.0005-0.0006之間,主要是0.0006

    結(jié)論:偏移offset較小的時(shí)候,直接使用limit較優(yōu)。這個(gè)顯示是子查詢的原因。

    2、offset大的時(shí)候。

    select * from yanxue8_visit limit 10000,10

    多次運(yùn)行,時(shí)間保持在0.0187左右

    Select * From yanxue8_visit Where vid >=(
      Select vid From yanxue8_visit Order By vid limit 10000,1
    ) limit 10

    多次運(yùn)行,時(shí)間保持在0.0061左右,只有前者的1/3。可以預(yù)先offset越大,后者越優(yōu)。

    mysql> SELECT * FROM table LIMIT 95,-1; // 檢索記錄行 96-last.

    //如果只給定一個(gè)參數(shù),它表示返回最大的記錄行數(shù)目.

    posted @ 2010-06-02 14:43 BlakeSu 閱讀(451) | 評(píng)論 (0)編輯 收藏

    枚舉類型enum示例




    public enum OrderStatus {
        A(
    1), B(2), C(3), D(4), F(5), INCOMPLETE(6);
        
        
    private final int value;
        
    /**
         * Constructor.
         
    */
        
    private OrderStatus(int value) {
            
    this.value = value;
        }
        
        
    /**
         * Get the value.
         * 
    @return the value
         
    */
        
    public int getValue() {
            
    return value;
        }

    }


    posted @ 2010-06-02 13:33 BlakeSu 閱讀(147) | 評(píng)論 (0)編輯 收藏

    JS try.....catch的使用

    <script language="javascript">
    try
    {
    throw new Error(10,"asdasdasd")
    }
    catch (e)
    {
    alert(e.message);
    alert(e.description)
    alert(e.number)
    alert(e.name)
    throw new Error(10,"asdasdasd")
    }

    </script>  

    在JavaScript可以使用try...catch來進(jìn)行異常處理。例如:  

     

    try {
    foo.bar();
    } catch (e) {
    alert(e.name + ": " + e.message);
    }

    目前我們可能得到的系統(tǒng)異常主要包含以下6種:

    • EvalError: raised when an error occurs executing code in eval()  
    • RangeError: raised when a numeric variable or parameter is outside of its valid range  
    • ReferenceError: raised when de-referencing an invalid reference  
    • SyntaxError: raised when a syntax error occurs while parsing code in eval()  
    • TypeError: raised when a variable or parameter is not a valid type  
    • URIError: raised when encodeURI() or decodeURI() are passed invalid parameters  

    上面的六種異常對(duì)象都繼承自Error對(duì)象。他們都支持以下兩種構(gòu)造方法:

     

    new Error();
    new Error("異常信息");

    手工拋出異常的方法如下:

     

    try {
    throw new Error("Whoops!");
    } catch (e) {
    alert(e.name + ": " + e.message);
    }

    如要判斷異常信息的類型,可在catch中進(jìn)行判斷:

     

    try {
    foo.bar();
    } catch (e) {
    if (e instanceof EvalError) {
       alert(e.name + ":" + e.message);
    }
    else if (e instanceof RangeError) {
       alert(e.name + ": " + e.message);
    }
    // etc
    }

    Error具有下面一些主要屬性:

    • description: 錯(cuò)誤描述 (僅IE可用).  
    • fileName: 出錯(cuò)的文件名 (僅Mozilla可用).  
    • lineNumber: 出錯(cuò)的行數(shù) (僅Mozilla可用).  
    • message: 錯(cuò)誤信息 (在IE下同description)  
    • name: 錯(cuò)誤類型.  
    • number: 錯(cuò)誤代碼 (僅IE可用).  
    • stack: 像Java中的Stack Trace一樣的錯(cuò)誤堆棧信息 (僅Mozilla可用).  

    因此為了更好的了解錯(cuò)誤信息我們可以將catch部分改為如下形式:  

     

    try {
    foo.bar();
    } catch (e) {
    if (browserType != BROWSER_IE) {                            
       alert("name: " + e.name +
        "message: " + e.message +
        "lineNumber: " + e.lineNumber +
        "fileName: " + e.fileName +
        "stack: " + e.stack);        
    }
    else {                    
       alert("name: " + e.name +     
        "errorNumber: " + (e.number & 0xFFFF ) +
        "message: " + e.message");        
    }
    }

    JavaScript中的throw命令事實(shí)上可以拋出任何對(duì)象,并且我們可以在catch接受到此對(duì)象。例 如:

     

    try {
    throw new Date(); // 拋出當(dāng)前時(shí)間對(duì)象
    } catch (e) {
    alert(e.toLocaleString()); // 使用本地格式顯示當(dāng)前時(shí)間
    }

    posted @ 2010-06-02 10:38 BlakeSu 閱讀(330) | 評(píng)論 (0)編輯 收藏

    深拷貝

    import java.io.*;

    public class ObjectCloner
    {
       
    // so that nobody can accidentally create an ObjectCloner object
       private ObjectCloner(){}
       
    // returns a deep copy of an object
       static public Object deepCopy(Object oldObj) throws Exception
       {
          ObjectOutputStream oos 
    = null;
          ObjectInputStream ois 
    = null;
          
    try
          {
             ByteArrayOutputStream bos 
    = new ByteArrayOutputStream(); 
             oos 
    = new ObjectOutputStream(bos); 
             
    // serialize and pass the object
             oos.writeObject(oldObj);   
             oos.flush();               
             ByteArrayInputStream bin 
    = new ByteArrayInputStream(bos.toByteArray()); 
             ois 
    = new ObjectInputStream(bin);
             
    // return the new object
             return ois.readObject();
          }
          
    catch(Exception e)
          {
             System.out.println(
    "Exception in ObjectCloner = " + e);
             
    throw(e);
          }
          
    finally
          {
             oos.close();
             ois.close();
          }
       }
       
    }

    posted @ 2010-05-25 09:30 BlakeSu 閱讀(176) | 評(píng)論 (0)編輯 收藏

    mysql convert int to char/varchar

    select cast(1 as char)

    char 不能換成varchar,否則會(huì)報(bào)錯(cuò)。

    posted @ 2010-05-12 17:12 BlakeSu 閱讀(2894) | 評(píng)論 (0)編輯 收藏

    How to check Linux distribution and version?

    If u are on an unknown server and keen to know it’s linux distribution info, you can check the linux distribution info by just a single command (eg. version, codename, etc). Just tested this command in UBuntu and CentOS, both return as what i expected. :)

    To check linux distribution and version, follow the steps below:-

    • Start your terminal and enter the command below to show your the linux distribution info:-
      $ cat /etc/*-release
    • Here’s my result in one of my my Ubuntu box:-
      $ cat /etc/*-release
      DISTRIB_ID=Ubuntu
      DISTRIB_RELEASE=9.10
      DISTRIB_CODENAME=karmic
      DISTRIB_DESCRIPTION="Ubuntu 9.10"

      Cool right!

    posted @ 2010-05-08 13:29 BlakeSu 閱讀(684) | 評(píng)論 (0)編輯 收藏

    Eclipse集成windows資源管理器簡(jiǎn)單方法

    Run-->External Tools-->External tools configurations
    new 一個(gè) program
    location 里面填 :C:\WINDOWS\explorer.exe
    Arguments 里面填: ${container_loc}
    點(diǎn)擊 Run

    posted @ 2010-05-08 08:40 BlakeSu 閱讀(262) | 評(píng)論 (0)編輯 收藏

    commons lang 比較有用的類

    ArrayUtils                 //簡(jiǎn)化數(shù)組的操作
    LocaleUtils
    SerializationUtils
    StringEscapeUtils
    StringUtils
    SystemUtils
    Validate                   //輸入?yún)?shù)驗(yàn)證
    NestableException
    NestableRuntimeException
    StopWatch          //秒表類

    posted @ 2010-04-26 10:16 BlakeSu 閱讀(207) | 評(píng)論 (0)編輯 收藏

    xmind 當(dāng)真不錯(cuò)

    xmind是繪制思維導(dǎo)圖的工具。
    使用之后,發(fā)現(xiàn)繪制組織結(jié)構(gòu)圖和wbs都很方便。
    軟件基于eclipse框架開發(fā),反應(yīng)速度和操作性也都很不錯(cuò)。
    更重要的,圖形的效果也是專業(yè)級(jí)的 :)

    posted @ 2010-04-23 09:51 BlakeSu 閱讀(249) | 評(píng)論 (0)編輯 收藏

    僅列出標(biāo)題
    共12頁: 上一頁 1 2 3 4 5 6 7 8 9 下一頁 Last 
    主站蜘蛛池模板: 国产永久免费高清在线| 91视频免费网址| 亚洲黄黄黄网站在线观看| 国产精品极品美女自在线观看免费| 黑人大战亚洲人精品一区| 99精品热线在线观看免费视频| 亚洲 欧洲 视频 伦小说| 在线a亚洲v天堂网2018| 无码免费一区二区三区免费播放| 亚洲人成图片网站| 久久精品亚洲乱码伦伦中文| 久草免费在线观看视频| 成人午夜影视全部免费看| 亚洲一本综合久久| 国产成人免费a在线视频app| 国产麻豆成人传媒免费观看| 亚洲av永久无码一区二区三区 | 亚洲午夜无码AV毛片久久| 鲁大师在线影院免费观看| 在线观看亚洲免费| 精品无码一区二区三区亚洲桃色| 日本特黄a级高清免费大片| 久久aⅴ免费观看| 美女视频免费看一区二区| 亚洲视频在线观看网站| 亚洲国产中文字幕在线观看| 无码国产精品一区二区免费式影视| 一本到卡二卡三卡免费高| 亚洲性无码一区二区三区| 久久精品亚洲综合| 免费国产成人高清视频网站| 97人妻无码一区二区精品免费| a色毛片免费视频| 全黄A免费一级毛片| 亚洲一区二区三区免费在线观看 | 亚洲精品美女网站| 亚洲阿v天堂在线| 亚洲国产综合无码一区二区二三区 | 亚洲线精品一区二区三区| 日韩精品视频免费观看| 0588影视手机免费看片|