資訊人員盤點時的痛

十二月 31, 2009 by Benson · 2 Comments
Filed under: 學習筆記 

這幾天公司在盤點,12月的帳還沒有關掉,但是會計在之前會議已經說過了,25日之後不再進出庫,首先說為什麼還不關帳。
因為參數的關閉,把帳別開在2010年的1月時,目前生產的報工就沒有辦法進行,但是又要管制進出貨怎麼辦?

鼎新ERP使用的是Oracle Database,其實也沒有這麼難,只要把庫存交易檔鎖起來就好。
登入sqlplus之後,指令如下
lock table tlf_file in exclusive mode;

系統會回覆
Table(s) Locked.
表示資料表已經鎖定

這麼做有幾個好處,各部門就算開單了,也無法進行過帳,不能過庫就不會造成庫存異動,還好,這樣就不用再去重印盤點標籤了(驚)。

怎麼解鎖呢?其實也蠻簡單的
只要輸入commit;指令或是連線串斷(session中斷),lock就解鎖了

如果要鎖定一段時間怎麼做(定時鎖定table)
其實也很簡單
到ERP的主機上,登入任一個TTL(2~6,請按ctrl+alt+[2~6])
登入ERP環境(Profile),再進到sqlplus
輸入上面的指命
先鎖住

再來就是使用ps aux看看這個TTL的PID
寫一個小的script放入cron job
使用kill PID -9指命 強迫TTL中的程式(sqlplus)結束
就可以定時解開了,當然,解開了之後
還是要把script拿掉
不然同一個PID還有可能被別的程式用到
到時誤殺了可就不好了

在Linux下使用php連線oracle database

九月 30, 2009 by Benson · Leave a Comment
Filed under: 測試-軟體 

之前看網路上的資料,使用php連線oracle都不成功,今天剛好有空,就來測一下吧!

網路上的資料,大多都是教大家怎麼在Windows下使用appserver來連線oracle database,也有人介紹ODBC的方式來抓資料,但是ODBC是微軟的產品,並不是所不尚平台上都有這個元件可以呼叫,而且也為了系統穩定度,linux下開發php一直是小弟我的工作需要。之前看了某一篇文章,介紹linux下使用php連線oracle db,但是測試失敗,由於沒有急迫性,所以也就沒有繼續測下去,現在,急迫性出現,剛好今天晚上也有空,那就來測試一下吧!

測試的環境如下

一、CentOS 5.3
二、內建的php
三、內建的OCI連接元件

也就是說,灌好CentOS Linux就可以直接連Oracle了,之前網路上的給的概念都有一些些問題。

其實,今天測起來還蠻順的,在linux下使用php連接oracle db的動作如下

1.檢查php.ini 看看extension有沒有 oci8.so

檢查php中是不是有orcale的連接元件

2.使用OCI指令來寫個測試的PHP
<?php
oci_connect();
?>
這個只是測試oci元件是不是正常運作
當然,會出現錯誤訊息,因為沒有給足夠多的參數,正常畫面如下

2009-09-30_205400.jpg
3.寫個oracle DB連線的php吧
$con=oci_connect(‘user’,'password’,'db’) or die (‘Fail to connect Oracle DB’);
對oracle 來說,資料庫稱為user,因為它是先規劃table space(SID),再在table space上建立user,再在user中建資料表。
不過,第三個參數講成db名稱是怪怪的,我是使用SID才連線成功的,因為兩台linux是不同一台。

php原廠文件說 db是選擇性的,請參考這裡,內容可能是orcale 的instance或是tnsnames,如果沒有指定,PHP使用的環境變量ORACLE_SID和TWO_TASK確定的名稱,當地的Oracle實例和tnsnames.ora中相應的位置。

另外還可以指定字集,以及連線的模式,連線的模式可以是OCI_OPERATOR/OCI_SYSDBA,假設要指定連線模式,還需要使用oci8.privileged_connect來設定。

$req=oci_parse($con,’sql statement’) or die (‘Fail to get data’);
oci_execute($req);
接下來就是取出資料了!可以用do while來把資料拿出來
當然也可以用for loop來做,就看各位看官的習慣囉!

while ($row=oci_fetch_assoc($req)){
foreach ($row as $item){
echo $item. "\n";
}
}

oci_fetch_assoc應該是計算有多少筆資料的涵式

測試結果,成功使用php連接鼎新tiptop GP5,tiptop GP5是使用linux版的oracle 11G,我看日後有一些報表的開發,真的可以自己來囉!另一套使用oracle的系統也是11g,不過是在windows server 2003 R2上,所以還要再找時間去測看看!

php5連接Oracle資料庫

七月 9, 2008 by Benson · Leave a Comment
Filed under: 測試-軟體 

因為工作的需要~需要透過php去連接Oracle資料庫

php除了連接mysql之外~也要連接Oracle資料庫
因為~公司主要的資料庫都是Oracle10g
1.鼎新tiptop GP5
2.MES

所以想利用php去oracle裡抓資料出來用~
我的php環境是Base on php5之上~
使用的OS~是Centos 5.0版
記憶體512MB ASUS 1U Server

Oracle原廠網站上提供了兩隻rpm
分別是
oracle-instantclient-basic-10.2.0.4-1.i386.rpm
oracle-instantclient-devel-10.2.0.4-1.i386.rpm

但是這兩隻rpm的處理方式~
在官方文件中說的不清楚~
而且~如果要讓php在apache中被支援~
這整個動作變的很麻煩~
要重新編過apache(httpd)
所以最簡單的處理方式就是動態載入 Read more