2018年6月27日 星期三

2018年6月22日 星期五

notepad ++ 喜歡的配色


Notepad ++ 喜歡的配色 , 以cpp為例子

方法一: 懶人方法

(1) 設定 -> 設定程式語言格式 -> 主題選取(選擇 Monokai) 
(2) 在安裝目錄資料夾底下   %APPDATA%\Notepad++   打開 stylers.model.xml
(3) 開啟 stylers.model.xml 尋找 c ++ 關鍵字
(4) 把這些覆蓋過去

<LexerType name="cpp" desc="C++" ext="">
            <WordsStyle name="PREPROCESSOR" styleID="9" fgColor="804000" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="DEFAULT" styleID="11" fgColor="000000" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="INSTRUCTION WORD" styleID="5" fgColor="0000FF" bgColor="FFFFFF" fontName="" fontStyle="1" fontSize="" keywordClass="instre1" />
            <WordsStyle name="TYPE WORD" styleID="16" fgColor="8000FF" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" keywordClass="type1" />
            <WordsStyle name="NUMBER" styleID="4" fgColor="FF8000" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="STRING" styleID="6" fgColor="808080" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="CHARACTER" styleID="7" fgColor="808080" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="OPERATOR" styleID="10" fgColor="000080" bgColor="FFFFFF" fontName="" fontStyle="1" fontSize="" />
            <WordsStyle name="VERBATIM" styleID="13" fgColor="000000" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="REGEX" styleID="14" fgColor="000000" bgColor="FFFFFF" fontName="" fontStyle="1" fontSize="" />
            <WordsStyle name="COMMENT" styleID="1" fgColor="008000" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="COMMENT LINE" styleID="2" fgColor="008000" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="COMMENT DOC" styleID="3" fgColor="008080" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="COMMENT LINE DOC" styleID="15" fgColor="008080" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="COMMENT DOC KEYWORD" styleID="17" fgColor="008080" bgColor="FFFFFF" fontName="" fontStyle="1" fontSize="" />
            <WordsStyle name="COMMENT DOC KEYWORD ERROR" styleID="18" fgColor="008080" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="PREPROCESSOR COMMENT" styleID="23" fgColor="008000" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="PREPROCESSOR COMMENT DOC" styleID="24" fgColor="008080" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
        </LexerType>

方法二:

(1) 設定 -> 設定程式語言格式 -> 主題選取(選擇 Monokai) 
(2) 左邊程式語言選擇 C++
(3) 樣式部分:
                        INSTRUCTION WORD: 字色修改成藍色(色調,濃度,亮度) = (140,240,142)
                        TYPE WORD: 字色修改成藍色(140,240,142)
                        NUMBER: 字色修改成藍色(140,240,142)
                        OPERATOR: 字色修改橘色(13,240,150)


2018年6月19日 星期二

移除討人厭的 dll 檔案

以下範例為 Notepad ++ 的 NppShell.dll 刪不掉

刪除指令如下:

(1) 先進到 Notepad ++ 目錄底下
(2) tasklist /m NppShell_06.dll
(3) 可以看到哪個 .exe 占用 NppShell_06.dll
(4) 發現 explorer.exe 檔案 ( 不能亂關 ) , 所以我們要下指令
(5) taskkill /f /PID 3268  (註: 3268是我畫面上的 PID)
(6) 此時桌面消失 , 不用緊張
(7) 重啟 explorer.exe 即可



2018年6月15日 星期五

C 語言 Strtok 用法與原理

程式碼:


















一開始的變數:







(1)   執行完 p = strtok(mailList, delim); , Strtok 會把 ; 的地方塞入 ‘\0’
可以把 mailList 想像成 hsiwei@kenda.com.tw \0 alexsie@kenda.com.tw
因為mailLisr 被填入\0
所以值那邊只會抓到 hsiwei@kenda.com.tw 但其實後面還有alexsie@kenda,com,tw
然後指標 p 會指向mailList的這塊記憶體位置

如下圖


(2) 因為p!=NULL 所以進入到 while迴圈, 接著執行 p = strtok(NULL, delim);
由於 ‘\0’就是 NULL , 所以指標pNULL開始往後找, 找到下一個 ; 為止

執行完後變數如下圖


用圖片來說明

2018年5月28日 星期一

[ ORACLE ] 顯示某Table 所有欄位語法

參考網站:
https://stackoverflow.com/questions/452464/how-can-i-get-column-names-from-a-table-in-oracle


記得 table_name 要大寫, ORACLE 很在意大小寫的 😃

SELECT table_name, column_name, data_type, data_length
FROM USER_TAB_COLUMNS
WHERE table_name = 'MYTABLE'
ORDER BY column_id

2018年5月25日 星期五

oracle insert into ( columns : timestamp )

insert into test values ( TO_TIMESTAMP('2018-05-25 18:18:18.333', 'YYYY-MM-DD HH24:MI:SS.FF') )

2018年5月17日 星期四

抓取Log關鍵字的好用軟體 - UnixLike

此範例是在遠端桌面Server(Q:\)裏頭的log
關鍵字是: "UPDATE PPT1D.AEQPTRESV SET LOT_ID='U111805160014'"


抓關鍵字語法:
grep + 要找的關鍵字  + Log存放路徑 + > 要寫到哪個路徑.檔案裡

grep "UPDATE PPT1D.AEQPTRESV SET LOT_ID='U111805160014'" Q:\prod\stdv14_ora_msmq\mes\aplog\kap02\*_2018-05-17*.log > c:\test.txt





2018年5月10日 星期四

Oracle In 多重欄位作法

如果遇到有多個欄位,要做查詢
一般來說我們的直覺會是這樣下

SELECT * FROM AEQPTRESV WHERE 1=1 AND (LOT_ID = 'U101804270010' AND NX_OPE_NO='090010')OR    (LOT_ID = 'U101804270009' AND NX_OPE_NO='090010')OR    (LOT_ID = 'U101804270007' AND NX_OPE_NO='090010').........

但是這種作法太耗費效能了, 於是突發奇想是否可以這樣抓

SELECT * FROM AEQPTRESV 
WHERE 1=1 
AND (LOT_ID , NX_OPE_NO) 
IN (
           ('U101804270010','090010'),
           ('U101804270009','090010'),
           ('U101804270007','090010')
)

後來發現竟然可以 😃😃😃
語法改成這樣下,不但畫面比較好看,效能也會比較好哦!!!

2018年4月17日 星期二

sublime 安裝 Rails​Base​16 Color Schemes

1. 開啟sublime, ctrl+shift+P, 輸入inst, 選第一個( Package Control )










2. 輸入RailsBase16 Color Schemes, 按下enter後開始安裝
3. 之後再 Preferencr -> clolor scheme 就可以選擇剛剛安裝好的主題

2017年11月13日 星期一

Java Connect Informix DB example

(1)   Import ifxjdbc.jar 
 
(2) import java.sql.*;
(3) 注意連線字串
(4) 範例程式

package hhh;
import java.sql.*;


public class hahah {

public static void main(String[] args) {
    // TODO Auto-generated method stub
    Connection conn = null;
    Statement statement = null;
    ResultSet resultSet = null;
    
    String dbURL = "jdbc:informix-sqli://Host:port/database name:informixserver=servername;"
                                    +  "DB_LOCALE=zh_tw.big5;user=帳號;password=密碼;";
                   
    try {
    //測試連線
    Class.forName("com.informix.jdbc.IfxDriver");
System.out.println("Driver OK");
conn =DriverManager.getConnection(dbURL);
System.out.println("connection OK");

Statement query = null;
ResultSet rs = null;
try
{
query = conn.createStatement();
rs = query.executeQuery("SELECT * FROM TableName WHERE 條件= 'xxx'");
while (rs.next())
{
System.out.println(rs.getString(0));
}
rs.close();
query.close();
catch (SQLException exce)
{
System.out.println("Caught: " + exce.getErrorCode());
}
conn.close();
    catch (ClassNotFoundException drvEx)
    {
    System.err.println("Could not load JDBC driver");
    System.out.println("Exception: " + drvEx);
    drvEx.printStackTrace();
    }
    catch(SQLException sqlEx)
    {
    while(sqlEx != null)
    {
    System.err.println("SQLException information");
    System.err.println("Error msg: " + sqlEx.getMessage());
    System.err.println("SQLSTATE: " + sqlEx.getSQLState());
    System.err.println("Error code: " + sqlEx.getErrorCode());
    sqlEx.printStackTrace();
    sqlEx=sqlEx.getNextException();
    }
    }
}
}

2016年8月11日 星期四

group by 超好用

假如同一個人的資料更新過 但是為了歷史紀錄而保留該筆資料
像是home_no = A101就有好幾筆 那我該如何select 不重複的呢?
利用 GROUP BY 吧

Select * From owner Where update_time In (Select Max(update_time) From owner Group By home_no)

從很多資 home_no 中抓出最新一筆的 home_no

Java 一些應用 [ csv reader / array of class / for( : ) ]

分享一些工作上用到的寫法 ( java )  csv reader  array of class for (:)  因為工作上需要讀取csv檔案的需求 , java 本身有提供一些 method  首先要 import opencsv-3.8.jar ...