2010年12月29日 星期三
用 Java 做簡單的 Thread pool
import java.util.concurrent.Executor;
import java.util.concurrent.Executors;
public class TestExecutor {
public static class Command implements Runnable {
private int id;
public Command(int id) {
this.id = id;
}
public void run() {
System.out.println(id + " Begin " + Thread.currentThread().getName());
try {
Thread.sleep(3000);
}
catch (InterruptedException ex) {
ex.printStackTrace();
}
System.out.println(id + " End " + Thread.currentThread().getName());
}
}
public static void main(String[] args) {
Executor tp = Executors.newFixedThreadPool(3);
tp.execute(new Command(1));
tp.execute(new Command(2));
tp.execute(new Command(3));
tp.execute(new Command(4));
tp.execute(new Command(5));
}
}
2010年11月17日 星期三
Mysql中count(*),DISTINCT的使用方法和效率研究
突然發現mysql對於count(*)的不同處理會造成不同的結果
比如執行
SELECT count(*) FROM tablename
即使對於千萬級別的數據mysql也能非常迅速的返回結果
而對於
SELECT count(*) FROM tablename WHERE…..
mysql的查詢時間開始攀升
仔細查閱累下手冊,發現當沒有WHERE語句對於整個mysql的表進行count運算的時候
MyISAM類型的表中保存有總的行數,而當添加有WHERE限定語句的時候Mysql需要對整個表進行檢索
從而得出count的數值
突然又想起來看到的不少新興的php程序對於count的處理並沒有很好的意識到這點
記錄下
順便提下mysql的DISTINCT的關鍵字有很多你想不到的用處
2010年9月16日 星期四
Regular Expression (RegExp) in JavaScript
Regular Expression (以下簡稱 REGEX) 是以一組特定字元符號描述字串樣式規則的記述語法。簡單地說, REGEX 用於表達字元符號在字串中出現的規則。舉個例子說明,在 REGEX 中,字元 '^' 放在第一個位置表示字串開頭位置,當我寫下 ^A
的記述時,便表示必須是一個開頭為 A
的字串,如 Adam,才符合此一規則。這個表達規則通常稱為 pattern 。 ECMAScript/JavaScript 以內建的 RegExp Object 提供 REGEX 功能。See also: ECMA-262 15.10 - RegExp Objects
要產生一個 RegExp 個體有兩種方式。第一種是直接以斜線 (/
) 包住 pattern ,例如 /^A/
。注意不要再用單引號或雙引號包在斜線外圍,一但用了引號圍住,就只是一個 String 而非 RegExp 個體。 "/^A/"
就是錯誤寫法,這只是一個普通字串。第二種是向系統要求建立一個 RegExp 個體,即 new RegExp(pattern)
,引數 pattern 可以是一個字串也可以是另一個 RegExp 個體。第一種方法只能使用常值的 pattern ,我們不能用斜線包住一個變數或一個字串運算結果。如果 pattern 保存在變數之中,則必須使用第二種方式。
RegExp 個體提供兩個主要行為,即 exec() 和 test() 。 exec() 會對引數字串進行比對運算,並將匹配的字串內容記錄在陣列中回傳。而 test() 則僅僅測試引數字串是否符合規則,只回傳 true
或 false
。此外,RegExp 個體也可以作為 String 個體的 match(), search(), replace(), split()
之引數。 String 的 match()
其實就是調用 RegExp 的 exec()
,兩者的結果相同。
2010年9月9日 星期四
JAVA日期問題總結.轉
【轉錄自某簡體網頁】
● JAVA日期問題總結
1、獲取服務器端當前日期:
<%@ page import="java.util.Date"%>
<%
Date myDate = new Date();
%>
2、獲取當前年、月、日:
<%@ page import="java.util.Date"%>
<%
Date myDate = new Date();
int thisYear = myDate.getYear() + 1900;//thisYear = 2003
int thisMonth = myDate.getMonth() + 1;//thisMonth = 5
int thisDate = myDate.getDate();//thisDate = 30
%>
3、按本地時區輸出當前日期
<%@ page import="java.util.Date"%>
<%
Date myDate = new Date();
out.println(myDate.toLocaleString());
%>
輸出結果為:
2003-5-30
Convert string to Date in JSP
<%@ page import= "java.util.Date,java.text.SimpleDateFormat, java.text.ParseException" %> <% String dateStr = request.getParameter("date"); SimpleDateFormat formater = new SimpleDateFormat("dd-MM-yyyy hh:mm:ss"); Date result = formater.parse(dateStr); out.println(result); %> |
2010年7月29日 星期四
java 判斷是否為數字
public boolean CheckNum(str){
for (int j=0;j < str.length();j++){
if (java.lang.Character.isDigit(str.charAt(j))){
} else {
return false;
break;
}
}
return true;
}
2010年7月19日 星期一
mysql語句中用if的例子
12.2. 控制流程函數
CASE value WHEN [compare-value] THEN result [WHEN [compare-value] THEN result ...] [ELSE result] END CASE WHEN [condition] THEN result [WHEN [condition] THEN result ...] [ELSE result] END
在第一個方案的返回結果中, value=compare-value。而第二個方案的返回結果是第一種情況的真實結果。如果沒有匹配的結果值,則返回結果為ELSE後的結果,如果沒有ELSE 部分,則返回值為NULL。
MySQL> SELECT CASE 1 WHEN 1 THEN 'one'
-> WHEN 2 THEN 'two' ELSE 'more' END;
-> 'one'
mysql> SELECT CASE WHEN 1>0 THEN 'true' ELSE 'false' END;
-> 'true'
mysql> SELECT CASE BINARY 'B'
-> WHEN 'a' THEN 1 WHEN 'b' THEN 2 END;
-> NULL
一個CASE表達式的默認返回值類型是任何返回值的相容集合類型,但具體情況視其所在語境而定。如果用在字符串語境中,則返回結果味字符串。如果用在數字語境中,則返回結果為十進制值、實值或整數值。
IF(exPR1,expr2,expr3)
如果expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),則IF()的返回值為expr2; 否則返回值則為expr3。 IF() 的返回值為數字值或字符串值,具體情況視其所在語境而定。
mysql> SELECT IF(1>2,2,3);
-> 3
mysql> SELECT IF(1<2,'yes ','no');
-> 'yes'
mysql> SELECT IF(STRCMP('test','test1'),'no','yes');
-> 'no'
如果expr2 或expr3中只有一個明確是NULL,則IF() 函數的結果類型為非NULL表達式的結果類型。
expr1 作為一個整數值進行計算,就是說,假如你正在驗證浮點值或字符串值, 那麼應該使用比較運算進行檢驗。
mysql> SELECT IF(0.1,1,0);
-> 0
mysql> SELECT IF(0.1<>0,1,0);
-> 1
在所示的第一個例子中,IF(0.1)的返回值為0,原因是0.1 被轉化為整數值,從而引起一個對IF(0)的檢驗。這或許不是你想要的情況。在第二個例子中,比較檢驗了原始浮點值,目的是為了了解是否其為非零值。比較結果使用整數。
IF() (這一點在其被儲存到臨時表時很重要) 的默認返回值類型按照以下方式計算:
表達式
返回值
expr2 或expr3 返回值為一個字符串。
字符串
expr2 或expr3 返回值為一個浮點值。
浮點
expr2 或 expr3 返回值為一個整數。
整數
假如expr2 和expr3 都是字符串,且其中任何一個字符串區分大小寫,則返回結果是區分大小寫。
http://blog.knowsky.com/
IFNULL(expr1,expr2)
假如expr1 不為NULL,則IFNULL() 的返回值為expr1; 否則其返回值為expr2。 IFNULL()的返回值是數字或是字符串,具體情況取決於其所使用的語境。
mysql> SELECT IFNULL(1,0);
-> 1
mysql> SELECT IFNULL(NULL,10);
-> 10
mysql> SELECT IFNULL(1/0,10);
-> 10
mysql> SELECT IFNULL(1/0,'yes');
-> 'yes'
IFNULL(expr1,expr2)的默認結果值為兩個表達式中更加“通用”的一個,順序為STRING、 REAL或INTEGER。假設一個基於表達式的表的情況, 或MySQL必須在內存儲器中儲存一個臨時表中IFNULL()的返回值:
CREATE TABLE tmp SELECT IFNULL(1,'test') AS test;
在這個例子中,測試列的類型為CHAR(4)。
NULLIF(expr1,expr2)
如果expr1 = expr2 成立,那麼返回值為NULL,否則返回值為expr1。這和CASE WHEN expr1 = expr2 THEN NULL ELSE expr1 END相同。
mysql> SELECT NULLIF(1,1);
-> NULL
mysql> SELECT NULLIF(1,2);
-> 1
注意,如果參數不相等,則MySQL 兩次求得的值為 expr1 。
引用:http://zxlm.cityk.cn/fh/viewthread.php?tid=1395
资料引用:http://www.knowsky.com/345280.html
CASE 指令,MySQL 的 switch 與 if else
- 必須依附在 SELECT,UPDATE,INSERT,DELETE 下
- 不可用在區段中加其他動作
- 具有 switch 與 if else 兩種架構
-- switch 的用法
SELECT CASE col
WHEN 100 THEN '1'
WHEN 50 THEN '2'
ELSE '3'
END
FROM table;
-- if else 的用法
SELECT CASE
WHEN col>100 THEN '1'
WHEN col>50 THEN '2'
ELSE '3'
END
FROM table;
-- IFNULL 的用法
SELECT IFNULL(a.col, b.col)
FROM table1 as a,table2 as b;
2010年4月12日 星期一
Linux下mysql中文問題
CentOS4.8、MySQL 5.1.45
現象:
在此電腦上安裝了Tomcat作為web服務器,部署了一個項目,通過jdbc連接到mysql數據庫。但是發現中文輸入輸出亂碼現象。
解決步驟:
1. 找到mysql的配置文件
網上說,mysql的配置文件就是/etc/my.cnf。但是這個文件並不一定存在,由於你可能採取的MySQL安裝方式跟網上所說的不一樣,就不一定能夠找得到/etc/my.cnf。因此,你需要使用find命令查找cnf文件。記得不要去找my.cnf因為它不一定存在,而應該找*.cnf。
VSFTP 設定與參數
相關檔案或目錄
/etc/vsftpd/vsftpd.conf //vsftpd的設定檔
/etc/pam.d/vsftpd //PAM模組設定檔,身份認證之用
/etc/vsftpd.ftpusers //pam模組用來指定某user無法登入的設定檔
/etc/vsftpd.user_list //依vsftpd.conf內的userlist_enable, userlist_deny參數設定而有不同功能
/etc/vsftpd.chroot_list //將某帳號chroot 在他們的家目錄下,和vsftpd.conf內的chroot_list_enable, chroot_list_file參數相關
/usr/sbin/vsftpd //主要執行檔
/var/ftp/ //匿名使用者登入的根目錄
常用功能設定做法
不讓某帳號離開家目錄
修改vsftpd.conf
2010年4月9日 星期五
PermGen space及其解決方法
2010年4月8日 星期四
Linux下mysql大小寫問題
1、Linux下mysql安裝完後是默認:區分表名的大小寫,不區分列名的大小寫;
2、用root帳號登錄後,在/etc/my.cnf 中的[mysqld]後添加添加lower_case_table_names=1,重啟MYSQL服務,這時已設置成功:不區分表名的大小寫;
MySQL帳號與權限設定
--------------------------------------------------------------------------------
請以MySQL管理者root身份登入MySQL,你可以使用「grant on」指令新增使用者與權限的調整。當使用者不存在時會建立帳號,若存在則會變更權限,grant on指令基本設定如下:
grant 權限 on 資料庫.資料表 to 帳號@主機 identified by‘密碼’
2010年4月7日 星期三
CentOS jdk1.6 安裝
http://java.sun.com/javase/downloads/index.jsp
下載 JDK jdk-6u19-linux-i586-rpm.bin
> chmod a+x jdk-6u19-linux-i586-rpm.bin
執行安裝
> ./jdk-6u19-linux-i586-rpm.bin
切換目錄到/usr/bin
> cd /usr/bin
作link
> ln -s -f /usr/java/jdk1.6.0_19/bin/java
> ln -s -f /usr/java/jdk1.6.0_19/bin/javac
> vim hello.java
按 i 進行編輯
Linux RPM 使用講解
原文出處:
作者: 我從山中來
http://tw.group.knowledge.yahoo.com/hacker-cracker/article/view?aid=1202
http://doc.linuxpk.com/153.html
歡迎參觀 AYO 阿佑 個人的電腦技術園地
http://tw.myblog.yahoo.com/kain-0913/
AYO阿佑 這次來講說,Linux 世界中,有一種工具叫做 RPM,
這個是 Linux 套件安裝、升級、更新 的方法之一,
先行說明一下幾個名詞解釋 :
RPM : 這是 Linux 安裝、升級、更新方法之一,泰半都是 Red Hat 公司出品的 Linux 居多,
會這麼說是因為是因為 RPM 全名叫做,RedHat Package Managmer,
所以 Red Hat 相關的 Linux,都 100% 支援此種方式,
例如 : RedHat、RHEL、Fedora Core、CentOS
DPKG : 這又是另外一種 Linux 安裝、升級、更新方法之一,源出自 Debian Linux,
而 Linux 中,N User 比較常聽過的 Ubuntu,也是支援這個方法喔!!
當然還有 FreeBSD 也是支援此方式做的喔!
CentOS移除以及安裝mysql-server
#yum remove mysql-server --->移除mysql-server
#rm -rf /var/lib/mysql/ --->徹底清除相關目錄
#yum -y install mysql-server --->安裝
#service mysqld restart --->重啟服務
#mysqladmin -u root password 填新密碼 --->變更mysql的root的密碼
2010年4月1日 星期四
SAXBuilder、Document、Element的用法
import org.jdom.Element;
import org.jdom.JDOMException;
import org.jdom.input.SAXBuilder;
import org.jdom.output.XMLOutputter;
(1)使用JDOM首先要指定使用什麼解析器。如:
SAXBuilder builder=new SAXBuilder(false); 這表示使用的是默認的解析器
(2)得到Document,我們以後要進行的所有操作都是對這個Document操作的:
Document doc=builder.build(xmlpath);
(3)得到根元素:
Element books=doc.getRootElement();
在JDOM中所有的節點(DOM中的概念)都是一個org.jdom.Element類,當然他的子節點也是一個org.jdom.Element類。
(4)得到元素(節點)的集合:
List booklist=books.getChildren("book");
這表示得到“books”元素的所在名稱為“book”的元素,並把這些元素都放到一個List集合中
(5)輪循List集合
for (Iterator iter = booklist.iterator(); iter.hasNext();) {
Element book = (Element) iter.next();
}
還有一種輪循方法是:
用JDom輕鬆整合Java和XML
Jdom是一個開源的api,它以直接易懂的方式向java程序員描述XML文檔和文檔的內容。就像名字揭示的那樣,Jdom是為java優化的。為使用XML文檔提供一個低消耗的方法。 Jdom的使用者可以不必掌握太多的XML的知識就可以完成想要的操作。
2010年3月31日 星期三
何時用JSP何時用Servlet?
JSP是讓熟悉網頁設計語法的網頁人員可以快速入門,當中不建議有Scriplet,也就是不建議出現<% Java語法 %>,而儘量使用EL、標籤、JavaBean、JSTL等。。。主要用於呈現畫面與資料,不是用於處理業務邏輯。。。
Servlet主要是給熟悉Java語言的開發人員而設計的,在Servlet中不建議出現有HTML內嵌的程式碼,會很難寫,Servlet通常是用於後端的處理,將處理完的資料封裝好之後,丟給JSP來呈現資料。。。
當然,您硬要只用JSP來撰寫,技術上是可行的,或您想用Servlet解決所有的事也是可以的。。。
然而最好的方法是JSP與Servlet相互合作,分好彼此的職責。。。
2010年3月30日 星期二
private int field;
public static void main(String[] args) {
System.out.println("Hello! World!");
}}
public 修飾子
class 類別
HelloWorld 類別名稱
void 回傳值
main 方法 (Method)
field 欄位 -> 屬性
命名慣例讓程式更容易被理解和閱讀。他們也可以給予關於識別子功能的
資訊 -- 例如,是否為常數,套件,或是類別 -- 這可以在瞭解程式碼時很有
幫助。
●package:英文全部使用小寫,例如:com.xx、java.lang....
●類別:每一個英文單字的第一個字母大寫,例如:Phoenix、PhoenixUtility
●介面:每一個英文單字的第一個字母大寫,例如:Phoenix、PhoenixUtility
●方法:第一個英文單字的英文字母小寫,其他單字的第一個英文字母大寫,例如:phoenix、phoenixUtility
●常數:英文字母全部大寫,且兩兩之間用底線隔開,例如:PHOENIX、PHOENIX_UTILITY
var myDate = new Date();
myDate.getYear(); //獲取當前年份(2位)
myDate.getFullYear(); //獲取完整的年份(4位,1970-????)
myDate.getMonth(); //獲取當前月份(0-11,0代表1月)
myDate.getDate(); //獲取當前日(1-31)
myDate.getDay(); //獲取當前星期X(0-6,0代表星期天)
myDate.getTime(); //獲取當前時間(從1970.1.1開始的毫秒數)
myDate.getHours(); //獲取當前小時數(0-23)
myDate.getMinutes(); //獲取當前分鐘數(0-59)
myDate.getSeconds(); //獲取當前秒數(0-59)
myDate.getMilliseconds(); //獲取當前毫秒數(0-999)
myDate.toLocaleDateString(); //獲取當前日期
var mytime=myDate.toLocaleTimeString(); //獲取當前時間
myDate.toLocaleString( ); //獲取日期與時間
if (mytime<"23:30:00")
{
alert(mytime);
}
</SCRIPT>
2.
<%
java.text.SimpleDateFormat formatter = new java.text.SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
java.util.Date currentTime = new java.util.Date();//得到當前系統時間
String str_date1 = formatter.format(currentTime); //將日期時間格式化
String str_date2 = currentTime.toString(); //將Date型日期時間轉換成字符串形式
%>
2010年3月22日 星期一
語言技術: JSP/Servlet
轉載自 Gossip@caterpillar
2010年3月18日 星期四
Java語言的寫作風格
Java語言的寫作風格
寫作Java程式時,請注意下列幾種風格
- Class Name請首字大寫
- Variable Name和Method Name請首字小寫
- 如果名稱由數個英文字組成,第二個英文字以後首字大寫
- 內縮四個空格
- 註解部分如要變成說明文件,請遵照javadoc這個工具的寫作規則