国产强伦姧在线观看无码,中文字幕99久久亚洲精品,国产精品乱码在线观看,色桃花亚洲天堂视频久久,日韩精品无码观看视频免费

      您現(xiàn)在的位置:智能制造網(wǎng)>技術(shù)中心>嵌入式數(shù)據(jù)庫在數(shù)控系統(tǒng)中的實現(xiàn)與應(yīng)用

      直播推薦

      更多>

      企業(yè)動態(tài)

      更多>

      推薦展會

      更多>

      嵌入式數(shù)據(jù)庫在數(shù)控系統(tǒng)中的實現(xiàn)與應(yīng)用

      2009年03月09日 18:12:50人氣:877來源:煙臺勾股通信技術(shù)有限公司

      1 引言

       

          本文所論述是數(shù)控系統(tǒng)大課題中人機交互的外圍部分子課題中的數(shù)據(jù)庫開發(fā)應(yīng)用。在數(shù)控加工系統(tǒng)中,存在著大量的用戶設(shè)定參數(shù)、系統(tǒng)參數(shù)、坐標軸參數(shù)、軸補償參數(shù)和刀具特征參數(shù)等數(shù)據(jù)。在整個生產(chǎn)制造系統(tǒng)中,這些數(shù)據(jù)不僅對于數(shù)控編程人員是必需的,而且對于實時過程控制系統(tǒng)、調(diào)度系統(tǒng)、工序處理、庫存管理系統(tǒng)、刀具維護管理系統(tǒng)等也是必需的。這些數(shù)據(jù)的組織管理方式對數(shù)控系統(tǒng)的實時性乃至性能影響很大,因此高性能數(shù)控系統(tǒng)必須解決數(shù)據(jù)的有效性組織管理問題。如果采用直接將數(shù)據(jù)存放在一個表或字符數(shù)組中,數(shù)據(jù)的修改與維護會相當困難、繁雜,這與數(shù)控系統(tǒng)對數(shù)據(jù)操作要求簡單方便與快捷相悖,因此這種組織管理方式不能滿足數(shù)控系統(tǒng)的要求。目前數(shù)控加工系統(tǒng)普遍采用的文本文件格式存儲管理數(shù)據(jù)的方式也存在著實時操作性較差和磁盤空間浪費嚴重的缺點,而實時性和存儲空間兩個要素對于高性能嵌入式數(shù)控系統(tǒng)來說卻是至關(guān)重要的。因此,在本課題研究中,作者提出在嵌入式Linux[1]環(huán)境下的數(shù)控系統(tǒng)中采用基于MySQL數(shù)據(jù)庫管理數(shù)據(jù)的全新技術(shù)解決方案。實踐結(jié)果表明:在嵌入式數(shù)控系統(tǒng)中采用數(shù)據(jù)庫進行數(shù)據(jù)管理,滿足了高性能嵌入式數(shù)控系統(tǒng)在實時性和存儲空間方面的要求,提高了系統(tǒng)的速度,極大地改善了系統(tǒng)的性能。

          本文就嵌入式數(shù)控系統(tǒng)中數(shù)據(jù)庫應(yīng)用開發(fā)的具體實現(xiàn)過程,以及如何將數(shù)據(jù)庫應(yīng)用程序向嵌入式數(shù)控系統(tǒng)硬件平臺的移植方法和對數(shù)據(jù)庫進行zui小化裁剪的技巧上做了詳細介紹。

          由于本課題開發(fā)的人機界面是利用GTK+圖形庫,因此系統(tǒng)中采用的基于MySQL數(shù)據(jù)庫應(yīng)用開發(fā),需要解決MySQL和GTK+相互融合的問題。GTK+ 沒有直接操作數(shù)據(jù)庫的控件,對數(shù)據(jù)庫的操作可以采取通過MySQL C API 直接進行,再調(diào)用GTK+ 的顯示功能的方法來完成與用戶的交互 [2] [3]。
        
      2 數(shù)據(jù)庫實現(xiàn)

      2.1 數(shù)據(jù)庫的建立

      2.1.1 創(chuàng)建work數(shù)據(jù)庫

           首先創(chuàng)建一個名稱為work的數(shù)據(jù)庫,并包含系統(tǒng)需要的所有表,作為根用戶連接到MySQL。具體創(chuàng)建過程如下:

      % mysql –uroot mysql;                           //進入數(shù)據(jù)庫

      mysql> SET PASSWORD=PASSWORD(‘lyw00001’); //為根用戶分配一個口令

      mysql> CREATE DATABASE work ;              //創(chuàng)建work數(shù)據(jù)庫

      mysql> GRANT ALL ON work.* to lyw@localhost IDENTIFIED BY ‘lyw00001’;//創(chuàng)建一個名為lyw的用戶

      //與根用戶使用同一口令,并為用戶賦予數(shù)據(jù)庫work的*訪問權(quán)限

      % mysql –ulyw –p lyw00001 work;                //連接庫

      2.1.2 創(chuàng)建表

           針對基于GTK+庫設(shè)計的用戶操作界面有若干個表與之相對應(yīng),下面以一個界面為例詳細說明MySQL與GTK+的連接過程。

           連接到數(shù)據(jù)庫之后,就可以向它添加內(nèi)容了,使用CREATE命令來創(chuàng)建一個名為tbl_amend_amend的表。

      CREATE TABLE tbl_amend_amend ( 

      number INT NOT NULL PRIMARY KEY,

      shapeh VARCHAR(10),

      deleteh VARCHAR(10),

      shaped VARCHAR(10),

      deleted VARCHAR(10),);

           創(chuàng)建一個表后,可使用SQL語句INSERT命令向表中填入數(shù)據(jù),但這種方法當數(shù)據(jù)量大時會耗時很多。因此作者采用批處理模式向表中填入數(shù)據(jù)的方法,具體作法是:首先創(chuàng)建一個存儲SQL語句的文本文件amend_data.sql,如圖1所示;然后執(zhí)行SQL語句:

      % mysql –ulyw –p lyw00001 work < amend_data.sql

           就將圖1中的數(shù)據(jù)加入到tbl_amend_amend表中了,如表1所示。如果需要對數(shù)據(jù)進行修改,則只需要在amend_data.sql文本文件中進行,然后重新執(zhí)行一次上文中提到的語句就可以輕松地完成。

       

       
      圖1 amend_data文本文件
      表1 tbl_amend_amend表 

       

      2.2 連接模塊

           完成數(shù)據(jù)庫及表的創(chuàng)建,有了相關(guān)的數(shù)據(jù),下一步的工作就是在應(yīng)用程序中實現(xiàn)與數(shù)據(jù)庫的連接。應(yīng)用程序中用connect_to_db()模塊實現(xiàn)了與數(shù)據(jù)庫work連接功能,模塊代碼如下:

      void Connect_to_db(){……; 

      conx = mysql_init((MYSQL *)0L);   //初始化

      ……;

      temp = mysql_real_connect(conx,126.0.0.1, lyw,lywcita001, work, 0, 0L, 0);

      ……;}

      mysql_real_connect函數(shù)用于連接到名稱為conx 的MySQL服務(wù)器,其主機的IP地址為“127.0.0.1”,用戶名為“lyw”,密碼為“lywcita001”,連接的數(shù)據(jù)庫名為work。

      2.3 填充模塊

          實現(xiàn)了與數(shù)據(jù)庫的連接后,接下來應(yīng)將數(shù)據(jù)庫的數(shù)據(jù)填充到用戶界面上去。應(yīng)用程序中用Fill_clist()模塊實現(xiàn)數(shù)據(jù)填充功能,其實現(xiàn)流程為:用MySQL查詢所需的數(shù)據(jù);將查詢結(jié)果保存在內(nèi)部緩存中;將緩存中的數(shù)據(jù)顯示在用戶界面上。模塊代碼如下:

      void Fill_clist(){ ……;

      gchar *amend_clist_row[5] = {,,,,};   //定義gtk+數(shù)組數(shù)據(jù)指針及變量  

      mysql_query(conx,select number,shapeh,deleteh,shaped,deleted from tbl_amend_amend);

      result_set = mysql_store_result(conx);           //將查詢結(jié)果保存在內(nèi)部緩存中

      num_fields = mysql_num_fields(result_set);      //獲得結(jié)果集中列的數(shù)量

      while(db_row = mysql_fetch_row(result_set)) {

      lengths = mysql_fetch_lengths(result_set);       //獲得列的長度

      amend_clist_row[0] = db_row[0];

      ……; 

      amend_clist_row[4] = db_row[4]; //將獲得的db_row字符串數(shù)組的值一一對應(yīng)地賦值給amend_clist_row

      gtk_clist_append(GTK_CLIST(modify_list),amend_clist_row); }//填充到clist對應(yīng)的域中

      mysql_free_result(result_set);}                          //釋放結(jié)果集所用的內(nèi)存

          編譯運行插入程序,實現(xiàn)了數(shù)據(jù)庫向用戶界面填充數(shù)據(jù)功能,獲得了如圖2所示的界面。

       


      圖2 MySQL填充圖

       

      2.4 更新模塊

          當用戶在界面上對系統(tǒng)參數(shù)進行修改后,希望將新的數(shù)據(jù)寫入數(shù)據(jù)庫保存,確保數(shù)據(jù)信息的一致性和連續(xù)性,因此應(yīng)用程序應(yīng)具有根據(jù)系統(tǒng)參數(shù)的改變而更新數(shù)據(jù)庫的功能。與填充模塊類似,應(yīng)用程序中用Update_database()模塊實現(xiàn)數(shù)據(jù)庫更新功能。
         
      3 數(shù)據(jù)庫移植 

      3.1 移植的硬件平臺

           本數(shù)控系統(tǒng)中采用了嵌入式PC平臺,嵌入式PC與標準PC機*兼容。因而,可以在普通PC上做好設(shè)計和開發(fā),再將軟件移植到嵌入式PC上。本系統(tǒng)開發(fā)采用嵌入式PC104計算機,硬件水平達到P3級,內(nèi)存為128M,程序存儲選用128M CF[4]卡。

      3.2 移植過程

           要在數(shù)控系統(tǒng)中應(yīng)用數(shù)據(jù)庫和操作界面,則需要將MySQL和操作界面應(yīng)用程序移植到CF卡中??紤]到CF卡的容量問題,在移植的過程中要對數(shù)據(jù)庫進行裁剪。

      3.2.1 mysqld運行服務(wù)器的移植

          要讓MySQL能運行在嵌入式系統(tǒng)中,那么mysqld運行服務(wù)器文件的移植有著至關(guān)重要的作用。用命令ldd mysqld查詢與mysqld可執(zhí)行文件相關(guān)的庫,結(jié)果如表2所示:

      表2  與mysqld可執(zhí)行文件相關(guān)的庫文件

       

      相關(guān)庫文件
      大小
      相關(guān)庫文件
      大小
      librt.so.1 => /lib/librt.so.1
      37K
      libstdc++.so.5 => /usr/lib/libstdc++.so.5
      71K
      libdl.so.2 => /lib/libdl.so.2
      15K
      libm.so.6 => /lib/tls/libm.so.6
      21K
      libpthread.so.0 => /lib/tls/libpthread.so.0
      79K
      libgcc_s.so.1 => /lib/libgcc_s.so.1
      30K
      libz.so.1 => /usr/lib/libz.so.1
      52K
      libc.so.6 => /lib/tls/libc.so.6
      1531K
      libcrypt.so.1 => /lib/libcrypt.so.1
      23K
      /lib/ld-linux.so.2 => /lib/ld-linux.so.2
      103K
      libnsl.so.1 => /lib/libnsl.so.1
      91K
       
       

       

          執(zhí)行文件mysqld的大小為3.3M,而其相關(guān)的庫文件的大小約為2M,將mysqld并同上述相關(guān)的庫文件一起移植到CF卡上,這樣mysqld便可在嵌入式硬件平臺上有效地執(zhí)行了。

      3.2.2 應(yīng)用文件的移植

           假定應(yīng)用程序的可執(zhí)行文件為app,用命令ldd app同樣可以查詢到與可執(zhí)行文件app相關(guān)的庫。將應(yīng)用程序連同與應(yīng)用程序執(zhí)行相關(guān)的庫文件一起移植到CF卡上。應(yīng)用程序的大小約為100K,與應(yīng)用程序執(zhí)行相關(guān)聯(lián)的庫文件的大小約為8M,而這8M的庫文件大部分為嵌入式Linux系統(tǒng)自身帶有的庫文件,基本上不需要再移植。這樣就可在嵌入式數(shù)控系統(tǒng)中運行用戶操作界面程序,而在后臺運行數(shù)據(jù)庫程序了。
        
      4 結(jié)束語

           CNC技術(shù)是現(xiàn)代加工技術(shù)的一個重要組成部分,如何在現(xiàn)有的技術(shù)基礎(chǔ)上不斷改進數(shù)控系統(tǒng)以滿足新的需求具有十分重要的意義。隨著機械加工領(lǐng)域?qū)?a title="數(shù)控系統(tǒng)" target="_blank" >數(shù)控系統(tǒng)的精度、效率、功能以及智能化程度[5]的進一步要求,控制面板、人機界面和系統(tǒng)數(shù)據(jù)組織管理方式等方面都需要不斷的完善和創(chuàng)新,系統(tǒng)數(shù)據(jù)的基于Mysql數(shù)據(jù)庫管理方式與目前數(shù)控系統(tǒng)普遍采用的文本文件管理方式相比,數(shù)據(jù)庫只需在一個導(dǎo)入文檔中修改更新數(shù)據(jù)就可以完成對數(shù)據(jù)的維護,操作簡單方便、快捷,并且數(shù)據(jù)庫索引在數(shù)據(jù)庫啟動時進駐內(nèi)存,對數(shù)據(jù)庫查詢、數(shù)據(jù)記錄的刪除和添加,索引能很方便、快捷地完成;數(shù)據(jù)庫zui小化裁剪后容量很小,因此,不論在實時性方面還是在存儲空間方面都滿足了高性能嵌入式數(shù)控系統(tǒng)的要求,提高了系統(tǒng)的速度,極大地改善了系統(tǒng)的性能。

       

      全年征稿/資訊合作 聯(lián)系郵箱:1271141964@qq.com

      免責聲明

      • 凡本網(wǎng)注明"來源:智能制造網(wǎng)"的所有作品,版權(quán)均屬于智能制造網(wǎng),轉(zhuǎn)載請必須注明智能制造網(wǎng),http://www.towegas.com。違反者本網(wǎng)將追究相關(guān)法律責任。
      • 企業(yè)發(fā)布的公司新聞、技術(shù)文章、資料下載等內(nèi)容,如涉及侵權(quán)、違規(guī)遭投訴的,一律由發(fā)布企業(yè)自行承擔責任,本網(wǎng)有權(quán)刪除內(nèi)容并追溯責任。
      • 本網(wǎng)轉(zhuǎn)載并注明自其它來源的作品,目的在于傳遞更多信息,并不代表本網(wǎng)贊同其觀點或證實其內(nèi)容的真實性,不承擔此類作品侵權(quán)行為的直接責任及連帶責任。其他媒體、網(wǎng)站或個人從本網(wǎng)轉(zhuǎn)載時,必須保留本網(wǎng)注明的作品來源,并自負版權(quán)等法律責任。
      • 如涉及作品內(nèi)容、版權(quán)等問題,請在作品發(fā)表之日起一周內(nèi)與本網(wǎng)聯(lián)系,否則視為放棄相關(guān)權(quán)利。

      <
      更多 >

      工控網(wǎng)機器人儀器儀表物聯(lián)網(wǎng)3D打印工業(yè)軟件金屬加工機械包裝機械印刷機械農(nóng)業(yè)機械食品加工設(shè)備制藥設(shè)備倉儲物流環(huán)保設(shè)備造紙機械工程機械紡織機械化工設(shè)備電子加工設(shè)備水泥設(shè)備海洋水利裝備礦冶設(shè)備新能源設(shè)備服裝機械印染機械制鞋機械玻璃機械陶瓷設(shè)備橡塑設(shè)備船舶設(shè)備電子元器件電氣設(shè)備


      我要投稿
      • 投稿請發(fā)送郵件至:(郵件標題請備注“投稿”)1271141964.qq.com
      • 聯(lián)系電話0571-89719789
      工業(yè)4.0時代智能制造領(lǐng)域“互聯(lián)網(wǎng)+”服務(wù)平臺
      智能制造網(wǎng)APP

      功能豐富 實時交流

      智能制造網(wǎng)小程序

      訂閱獲取更多服務(wù)

      微信公眾號

      關(guān)注我們

      抖音

      智能制造網(wǎng)

      抖音號:gkzhan

      打開抖音 搜索頁掃一掃

      視頻號

      智能制造網(wǎng)

      公眾號:智能制造網(wǎng)

      打開微信掃碼關(guān)注視頻號

      快手

      智能制造網(wǎng)

      快手ID:gkzhan2006

      打開快手 掃一掃關(guān)注
      意見反饋
      關(guān)閉
      企業(yè)未開通此功能
      詳詢客服 : 0571-87858618