天天看點

基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作)

    聽了我的建議,我們機關的食堂準備使用一台指紋考勤機統計吃飯人次,這樣院裡好給食堂的承包人以相應飯補。以前買過一台彩屏指紋機,資料庫是access的,今兒又買了一台準備放到食堂裡,而且考慮到停電,還特地配備了電池盒。

    這台不是彩屏的,但更加靈敏,反應速度比原來買的那台快,而且快不少。看看參數把:

基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作)
基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作)

    但有一樣,使用U盤下載下傳考勤資料時,是加密的.txt文檔,用他們公司的軟體才能把資料導入為Access表中。當然也可以自己弄.txt到.mdb的過程,但極為痛苦,極度難受,還很耗時。對于本周就上線運作的食堂管理系統而言,這是顯然不合适的。

    但是是可以實作的,這裡是ocx,說下實作思路:

    首先隻能使用IE浏覽器,通過調用ocx實作相關功能,就和一卡通裡的IC卡子產品一樣。接着執行個體化一個類,使用GetGeneralLogData()方法擷取記錄,麻煩的就在這了,得到的結果不是想當然的數組或是比較容易處理的類型。這塊很耗時。

    可以看一下函數的原型:

long GetGeneralLogData(long *apnEnrollNumber, long *apnVerifyMode,long *apnInOutMode, DATA *apnDateTime)

    執行成功傳回1,失敗傳回對應的錯誤代碼。要先用LoadGeneralLogData或USBLoadDataFromFile指令,不然該指令會執行失敗。

    不多說了,附件裡是ocx,呵呵,有興趣的自己研究去吧。這個思路都是浮雲,在規定的時間裡完不成的。涉及到調試ocx插件等等潛在問題,而且不是一個OCX或DLL的FKAttend就能搞定。我的方案是,使用他們給的工具導成mdb文檔,再導入到我這個一卡通的大資料庫裡,這樣所有記錄都能得到妥善儲存。而且上司也能一個頁面,足不出戶,檢視到食堂消費情況。

    是以要通過PHP,讀取mdb并寫入mysql。

    這次用的不是ThinkPHP,而是叫做DoitPHP的架構,也是頭一次使用,還以為比TP好用,看官網說資料處理特别快,但是不太容易掌握,總體還是略顯青澀。

    這是MDB檔案上傳子產品:

//資料庫檔案上傳

    public function uploadAction(){

        //儲存目錄檢測

        $dirurl = MDBDIR;

        $dir = $this->instance('file_list');

        $dir->make_dir($dirurl);

        $fileupload = $this->instance('file_upload');

        $new_file = $dirurl.MDBFILE;

        $result = $fileupload->upload($_FILES['upload'], $new_file);

        if(!$result){

            $this->assign('msg','檔案上傳失敗!');

            $this->saveAction();

        }

        if(!$this->inputDBAction()){

            $this->assign('msg','檔案導入資料庫失敗!');

        }else{

        $this->set_layout('usual');

        $this->assign('load_js_name','canteen');

        //display page

        $this->display('save');

    }

    上傳成功,就要自動填入Mysql中,這是PHP操作Access資料庫的子產品:

//access資料庫資訊導入

    public function inputDBAction(){

        if(file_exists(MDBDIR.MDBFILE)){

            $access = $this->module('access');

    //注意mdb是有密碼,但沒有使用者名

            $access->connect(MDBDIR.MDBFILE, '','2002', '', 0);

            $execarr = array();

            $result = $access->query("select * from ".mb_convert_encoding("考勤流水表", "GBK", "UTF-8")." where Used = No");

            while($arr = $access->fetch_array($result))

            {

             $execarr[] = $arr;

            }

            //現在寫入資料庫

             $att = $this->model('att_attendance');

             $flag = TRUE;

             foreach($execarr as $value){

                 $data = $att->createRow();

                 $data->userid = trim($value['UserID']);

                 $data->flowtime = strtr(trim($value['FlowTime']),'/','-');

                 $result = $att->save($data);

                 if($result 0){$flag = FALSE;break;}

             }

            return $flag;

    現在做查詢分組統計:

public function queryAction(){

        //權限驗證

        $checkauth = $this->module('Checkauth');

        $checkauth->checkAuth(CANTEEN);

        //設定日期

        if(!isset($_POST['start']) && !isset($_POST['end'])){

            //預設傳回最近1周的記錄

            $now = getdate();

            //********根據今天來确定本周的日期,開始************

            if($now['wday']==0)$foo = -7;

            else $foo = 1-$now['wday'];

            $start = $now['year'].'-'.$now['mon'].'-'.($now['mday']+$foo);

            if($now['wday']==0)$foo = 0;

            else $foo = 7-$now['wday'];

            $end = $now['year'].'-'.$now['mon'].'-'.($now['mday']+$foo);

             //********根據今天來确定本周的日期,結束************

            $result = $this->model('att_attendance');

            //求出分組統計

            $att = $result->execute("select att_attendance.userid,att_member.name,count(att_attendance.userid) as total from att_attendance,att_member WHERE att_attendance.userid = att_member.userid GROUP BY userid");

            //求得總數,使用Mysql嵌套查詢

            $sum = $result->execute("select sum(total) from (select att_attendance.userid,att_member.name,count(att_attendance.userid) as total from att_attendance,att_member WHERE att_attendance.userid = att_member.userid GROUP BY userid) as sum");

            //在這裡繼續,顯示出分組結果和總數結果,隻是還沒有把時間增加進去

            //對送出上來的start和end作出新的查詢

        exit();

        $this->display();

<b></b>

<b>    有幾個技術點需要記錄下來,以備忘:</b>

<b>    1、不能直接使用PhpMyAdmin構造的SQL,在這個例子中會失敗,問題出要出在FlowTime身上;</b>

<b>    2、格式問題,為了安全起見,要使用strtr把2011/11/11,替換為2011-11-11,為的是保持資料庫通用日期時間格式;</b>

<b>    3、在DoitPHP這個架構裡使用insert()或save()儲存資料時,面對object,而非array類型,盡量不要使用$data['UserID']的數組形式,會出現錯誤,而要采用$data-&gt;UserID;</b>

<b>    4、特别好玩的是,Access裡Boolean型的值有三種True/False,On/Off和Yes/No,我這裡mdb設定的就是Yes/No;</b>

<b>    5、注意mdb檔案是加密了的,當然也必須加密,否則食堂的人弄到mdb怎麼辦?當然mdb很容易就被破解了,不過上司看到的是我這個系統裡讀出的記錄,我不給他權限,他哪裡能把自己修改了的mdb檔案上傳給上司看呢。哈哈。上司,你要給我漲工資哦~~~</b>

    最後上傳并且自動導入成功:

基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作)
基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作)
基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作)
基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作)
基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作)

    當然這裡還用了一個access的PHP類,大家可以到我的這篇文章去看:

    <b>五嶽之巅原創,轉載請注明出處。謝謝。</b>

    附表:

SQL 文法元素

Microsoft 

Access

Microsoft SQL 

Server

辨別符

限制不超過 64 個字元。

允許使用關鍵字和特殊字元。

可以用任何字元開頭。

SQL Server 6.5:

限制不超過 30 個字元。

不允許使用關鍵字和特殊字元。

必須用字母字元開頭。

SQL Server 7.0 的辨別符與 Access 完全相容。

輸出字段

允許多個輸出字段具有相同名稱。

在視圖中不支援多個相同輸出字段名。

日期分隔符号

英鎊符(#)

撇号(')

Boolean 常量

True、False;On、Off;Yes、No。

整數:1(真)、0(假)

字元串連接配接

和号(&amp;)

加号(+)

通配符

星号(*)與零個或更多字元比對。

問号(?)與單個字元比對。

歎号(!)意味着不在清單中。

英鎊符(#)意味着單個數字。

百分号(%)與零個或更多字元比對。

下劃線(_)與單個字元比對。

上插入符(^)意味着不在清單中。

沒有與英鎊符(#)對應的字元。

TOP

如果有一個 ORDER BY 子句,自動包含層次。

SQL Server 6.5 不支援。

SQL Server 7.0 需要一個明确的 WITH TIES 子句。

CREATE INDEX

允許建立升序和降序索引。

允許聲明主鍵,沒有 Null 值,并且忽略 Null 值。

DROP INDEX

文法是:

Drop Index ON

Drop Index

DISTINCTROW

支援(允許選擇單個記錄)。

不支援。

OWNERACCESS

支援(在執行時控制許可權)。

Table in UNION

支援(允許使用下列文法指定表:

TABLE

ORDER BY in Unions

支援。允許通過聯合查詢中的子句實作多種排序。

支援。允許通過語句末尾的子句實作一種排序。

TRANSFORM

支援。用于交叉表查詢。

PARAMETERS

支援(在 SQL 中記錄)。

閱讀(11457) | 評論(5) | 轉發(2) |

給主人留下些什麼吧!~~

基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作)

項目做完了嗎?我們很感興趣,私聊下。

基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作)
基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作)

<b>huhuegg</b>: 吃飽了撐的.....呵呵,您一定是沒吃飽,告您一個秘密:食堂還有剩飯呢。

基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作)

就是别忘了機關進出人多,先到我這錄指紋,然後打卡才能吃飯,月末有詳單統計,人次、消費、補助一目了然。但就有一點,别怪我沒提醒,千萬别吃太飽,否則就真撐着了。

<a href="/uid/8676386.html"></a>

吃飽了撐的

基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作)

好熟悉的儀器呀!~

給力的文章,頂一下!

基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作)

必須支援!

基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作)

評論熱議

請登入後評論。

Copyright 2001-2010 ChinaUnix.net All Rights Reserved 北京皓辰網域網絡資訊技術有限公司. 版權所有

感謝所有關心和支援過ChinaUnix的朋友們

京ICP證041476号 京ICP證060528号