[分享] HTC Desire HD簡單開箱

_IGP0002.JPG

這幾天我也入手了HTC Desire HD (A9191)

只能講….爽度滿分

原本服役的Nokia 3120 classic可以退下來了

 

這台Desire HD(DHD),對大家來說應該不陌生

它在螢幕上的曝光度很高

到了現在,還是有店家購買需要預訂

(其實是打著現貨供應的店家,價格都很硬)

我是買空機,這是我的習慣

向網路上的賣家買的

一開始以為是詐諞集團哩 (今天新聞才在報導的說)

雖然我已經拿到比市價便宜很多的價格了

但怎麼還是比我的夢幻桌機還貴呢?

難道是要把電腦縮小帶著走的意思嗎?


 

我喜歡Desire HD的原因

1. CPU夠強悍

使用Qualcomm Snapdragon QSD8255 1GHz

據說可以超頻到1.5G,效能火力全開

2. 原本Desire使用者詬病RAM太小終於加大了

RAM記憶體768MB

存儲空間升級1.5G

不怕程式不夠放

3. 底下的觸控式按鈕很有質感

4. HD大螢幕爽度高

這應該目前沒有更大了吧,除了HD2外

5. Android的向下滑動感,真的很棒

有體驗過所有資料全在你指間的感覺嗎?

手上充滿滿滿的資訊,手指一滑,資料向上捲動

一頁、二頁、三頁(稍待5-6秒讀取快取)、四頁、五頁、六頁…….

真是妙不可喻


 

 

簡單手繪風格的盒子

_IGP0002.JPG

 

打開1:1包裝的盒子

_IGP0003.JPG

撕開膠膜

_IGP0004.JPG 

 

靜靜的躺在盒子上

_IGP0006.JPG

 

突然…一束光照到了手機,手機亮了起來

_IGP0009.JPG

 

 

 

有沒有想到HTC的廣告詞

 

「嘿,這個好!」

超高速網際網路瀏覽

_IGP0012.JPG

 

 

到底哪台才是真的?

_IGP0013.JPG

 

 

網友罵翻的乞丐背面

_IGP0014.JPG

背面再來一張

_IGP0015.JPG

 

 

看看配件包有甚麼

_IGP0016.JPG

 

快速上手說明書,保固申明

_IGP0017.JPG

 

 

配件一覽

_IGP0018.JPG

 

快速上手說明書

_IGP0019.JPG

因為不是買聯強貨,所以是英文的

_IGP0020.JPG

 

三個塑膠包

_IGP0021.JPG

 

特殊接頭的充電器,不過沒關係,到處都有賣轉接頭

_IGP0022.JPG

上方是個USB介面

_IGP0023.JPG

 

USB同步線,也拿來充電用

_IGP0025.JPG

 

驗明正身,真的是HTC

_IGP0028.JPG

 

耳機組,後方還很貼心的把海棉另外包

_IGP0029.JPG

 

_IGP0030.JPG

耳機的海綿

_IGP0031.JPG

_IGP0032.JPG

 

電源鈕在上面

_IGP0058.JPG

背面

_IGP0033.JPG

 

找到那傳說中很難開的電池蓋

要在那很細微的小橫洞,用指甲摳開

_IGP0034.JPG

 

然後掀起來

_IGP0035.JPG

就取下電池拉

 _IGP0037.JPG

網友也點名1230mAh的容量有點小

_IGP0038.JPG

 

打開下蓋吧,小心推就開了

_IGP0040.JPG

裡面有mircoSD卡和SIM卡槽

_IGP0041.JPG

下蓋全貌

_IGP0042.JPG

 

MircoSD很難拔?NoNoNo…他不是用"拔"的

而是要輕輕的推一下,就會彈出來

_IGP0043.JPG

原廠贈送的Samsung 8G MircoSD 是Class2的

_IGP0045.JPG

卡槽特寫

_IGP0046.JPG

下蓋特寫,網友說天線藏身在這裡

_IGP0047.JPG

電池蓋特寫,小心那細微的卡榫,很容易搞爆

_IGP0048.JPG

放入X寶電信的SIM卡

_IGP0049.JPG

蓋回電池蓋

_IGP0051.JPG

蓋回下蓋

_IGP0052.JPG

新舊手機來個走秀吧

_IGP0055.JPG

不彷來一張疊疊樂

3120 classic相信很多人有,這是Nokia最便宜的一台3G手機

_IGP0057.JPG

 

 


簡單測試拍照效果

 

會自動對焦

相機不再只有很蠢的拍照聲(一聽就知道是假的,我覺得這種聲音很好笑)

這台快門聲還好,至少對焦時還有機械的對焦聲

我一開始以為機器真的會機械對焦呢!

(結果關閉喇叭確認那真的是喇叭發出的對焦聲)

_IGP0062.JPG 

 

有一些簡單特效

_IGP0063.JPG

 

相機帶有一些特效

_IGP0064.JPG

 

網友說Desire HD普遍有這些問題:

1. 電池蓋卡粉緊

電池蓋那真的很鎖的很緊

不過對於帶二顆電池跑的使用者可能要改變習慣

感覺那蓋子摳久了會鬆

2. 下蓋很鬆,不密合

沒事別去摳它應該還OK吧

應該是因為下蓋含下半部的關係吧

3. 背面很醜,像補丁

我也這麼覺得耶,可能會用個硬殼全部卡起來吧

4. SD卡很難摳下來

先頂它一下會自己退出來

5. 耗電(比起普通手機而言)

聽朋友說智慧型手機普遍續航力不足,幾乎是每天充

有幾招可以教大家

A. 沒事別開太多的程式,或是讓很多程式在背景執行

這個可以到「menu→應用程式→正在運作的服務」的地方去管理

 

B. HTC的超大時鐘固然漂亮,其實可以換小,沒有太多的動畫可以省電

到「新增→小工具→HTC小工具」裡面找,會有很多你要的

 

C. 另外犧牲一些開機時間

到「menu→應用程式→快速開機」的功能去除

D. WiFi、藍芽用完了記得關

可以到「menu→設定→無線與網路」這裡去管理

也可以放一些小開關到桌面上(HTC小工具),比較方便

 

相信會省電很多,我讓他待機整天(不去玩他),大概可以待個2天吧

6. 喇叭音量很小

剛剛試打電話,鈴聲音量感覺中等

見仁見智摟,倒是震動頗震的

要從二樓手機響的人從一樓衝去接電話的人可能會漏接


我也是Android的新手,初次摸了Android後

對於換上智慧型手機使用者一些提醒

  1. 沒有內建檔案總管,要到market去找

  2. 凡事點錯了可以用底下的「回復」或叫「倒退」鍵

  3. 請慎選程式安裝,切記

 

第一篇大概就到這裡,等我摸熟一點再跟大家分享摟

 

 

手機內建儲存空間: 1.5 GB
RAM: 768 MB

[網芳問題] 登入失敗 未將這台電腦上要求的登入類型授與使用者

http://w-type.blogspot.com/2009/06/blog-post_13.html

當你要進入網路上另一台PC, 明明帳號密碼都有設好
但就是 進不去
建議以下設定
1.
1.1 開始/執行/gpedit.msc
1.2 到電腦設定->Windows設定->安全性設定->本機原則->使用者權限指派
1.3 檢查”從網路存取這台電腦” 設定是否包含該帳戶, 若沒有 請增加該帳戶(也可以增加 everyone)
1.4 檢查”拒絕從網路存取這台電腦”設定是否包含該帳戶, 若有 請移除

2. 可增加 NteBUIE通訊協定, 有時是TCP/IP 認定比較慢

3. 查閱要登入的電腦, 使用的帳號, 是否是被改過名稱, 可透過使用者帳戶, 該帳戶檢查 管理網路密碼資料 是否正確

4. 將police的檔案刪除 , 讓 它回到 default值, 就可以重新設定
4.1 將C:\WINDOWS\SYSVOL\sysvol\HTH.local\Policies\{6AC1786C-016F-11D2-945F-00C04fB984F9}\MACHINE\Microsoft\Windows NT\SecEdit\GptTmpl.inf 裏的SeNetworkLogonRight 刪除,這條Default Domain Controllers Policy的「從網路存取這台電腦」會變成尚末定義。
4.2 再執行gpedit.msc,在「電腦設定」>「Windows 設定」>「安全性設定」>「本機原則」>「使用者權利指派」裏的「從網路存取這台電腦」加上該帳戶 (也可以增加 everyone)
4.3 執行gpupdate /force,問題解決

[Fedora14]重灌筆記

這篇算是之前的文章的整理,有些東西可能就要煩請參考之前的文章摟

 

設定FireFox

http://gfx.tw/j796160836

關閉離線介面

http://j796160836.pixnet.net/blog/post/26241754

設定PPPOE連線,中文

http://j796160836.pixnet.net/blog/post/25444345

調整文字顯示模式

http://j796160836.pixnet.net/blog/post/26196073

解決在XP時間不同步的問題

http://j796160836.pixnet.net/blog/post/26041820

安裝相關的GUI介面

#yum install -y system-config-bind system-config-samba system-config-services system-config-boot system-config-network system-config-rootpassword policycoreutils-gui

[Flash AS3] 載入與按鈕 (2)

既然是有外部載入的,但有些問題可以討論的

A.swf載入B.swf

應該A.swf跟B.swf的畫格數不同
但我有在B.swf做按鈕,按下後將A.swf的畫格切換到指定畫格
載入其他的swf使用

由剛剛的方式就可以看到,MainTimeline能有多個但stage只有一個

OK.  這裡告訴你如何從A.swf設定事件在B.swf的按鈕上

先寫載入B.swf到myb_mc的語法

var loader = new Loader();
loader.contentLoaderInfo.addEventListener(Event.COMPLETE, loader_CompleteHandler);
loader.load(new URLRequest(“B.swf”));
myb_mc.addChild(loader);
loader.x = 0;
loader.y = 0;

這裡不同的是,多了一行語法,意思是偵聽事件,當載入完成後執行loader_CompleteHandler函數
在loader_CompleteHandler函數可以這麼寫

function loader_CompleteHandler(e:Event):void
{
   loader.getChildAt(0).btn01.addEventListener(MouseEvent.CLICK,btn01_clickHandler);
}

function btn01_clickHandler(e:MouseEvent):void
{
   /*一些程式碼*/
}

幫在B.swf的btn01按鈕掛上偵聽事件

————————————————————–

方式不同,但做法相同的另一個寫法
陣列寫法,事先定義好按鈕陣列
程式寫的時候一併附掛偵聽事件,再由引發事件主人的名字還判斷要做甚麼事

 

function loader_CompleteHandler(e:Event):void
{
 var buttonsArr:Array = [loader.getChildAt(0).btn01, loader.getChildAt(0).btn02];

 for (var i:int = 0; i< buttonsArr.length; i++)
 {
  buttonsArr[i].addEventListener(MouseEvent.CLICK,clickHandler);
 }
}

function clickHandler(e:MouseEvent):void
{
   switch (evt.target.name)
   {
     case “btn01” :
          /*一些程式碼*/
          break;
      case “btn02” :
          /*一些程式碼*/
          break;
    }
}

 

[Flash AS3] 載入與按鈕 (1)

完全沒碰過Flash的語法
或者以下我的文章大家如果看不懂

強烈建議手邊要有書!!!

因為AS3語法不會太簡單,我對這語法還不熟
這理做筆記用以免馬上忘記

這是普通載入一個swf或是圖檔的寫法

var loader = new Loader();   //設定loader為載入影片的物件
loader.load(new URLRequest(“home.swf”)); //設定載入來源名稱
addChild(loader);    //載入至舞台(stage)上
loader.x = 0;  //設定載入後的X位置
loader.y = 0;  //設定載入後的Y位置

 語法中addChild的前面如果沒寫字,就是載入到舞台上
而有寫名字就會載入到指定名稱的MovieClip上

例如

myMovieClip.addChild(loader);

=======================================================

先說說Flash的階層概念

在Flash中,大部分的東西都是物件(DisplayObject),只是有名字跟沒名字而已(可做程式化控制)
載有載入外部檔案的時候,MainTimeline可以有多個,而stage只有一個

根目錄是[object Stage]

假設空白舞台上有個MovieClip叫做show_me

[object Stage]>[object MainTimeline]>show_me [object  MovieClip]

———————————–

如何切換其路徑?

假設要切換到[object MainTimeline]
可以這樣測試

trace(stage.numChildren); 
trace(stage.getChildAt(0)); 

Output視窗就會顯示1[object MainTimeline]
意指stage下只有一個子物件,而該第0號物件為MainTimeline (主時間軸)

相關指令:
numChildren():int                      是該物件底下有多少子物件
getChildAt(index:int)                  抓取第n個子物件
getChildByName(name:String)   抓指定名稱的子物件

———————————–

剛剛有提到
例如載A.swf載入B.swf的時候,MainTimeline會有多個,而stage只有一個
B.swf獨立執行時,有它自己的stage

而被A.swf所載入時,MainTimeline的父物件會被換成loader

如何知道的?

有個指令叫parent抓取其父物件

if (getChildAt(0).parent.parent == this.stage)
{
   trace(“並未由外部載入”);
}
else
{
   trace(“由外部載入”);
   trace(getChildAt(0).parent.parent);
}

這是判斷swf是否從外部載入,可判斷該swf執行時有沒有看到stage
外部載入這行就會顯示該loader物件為誰

 

 

 

[MySQL] 解決中文亂碼,預設編碼改為UTF-8設定

這個設定幾乎是設定MySQL必備的設定

這問題特別在xampp的環境(Windows版和Linux版)下,或者Fedora Linux使用yum安裝的mysqld會出現的問題

 

新增表格如果不指定編碼,預設會用latin1

在C:\xampp\mysql\bin\my.ini     (Windows版的路徑)

找到 [client] 區塊

加入

default-character-set=utf8

找到 [mysqld] 區塊

加入

character-set-server=utf8
collation-server=utf8_general_ci

———————————————————————–

如果是Linux的Xampp for linux,用命令列打入
vi /opt/lampp/etc/my.cnf

如果是yum裝的mysqld,用命令列打入

vi /etc/my.cnf

照Windows的敘述做修改

[Fedora12]Linux的GRUB修復,安裝GRUB

大家在製作多重開機時都會遇到這個問題
就是不管是XP先安裝或是Linux先安裝

都會有開機資訊被覆蓋的情況

先講重要概念

————————————————————————–

重要概念

1. MBR為Master Boot Record每顆硬碟只有一個,寫在硬碟的第0軌上

2. 每切出的分割,除了裡面有檔案系統的資訊外,還有一個開機資訊(boot sector)

3. 大致的開機流程是,當BIOS控制權轉交到一顆硬碟上,會先讀取該硬碟的MBR
再由MBR裡寫的資訊(如果沒有則為active的分割區),載入該分割區的(boot sector),再經由該資訊,找到系統重要檔案,載入作業系統

4. 而多重開機則大多為在MBR裡寫入開機管理程式,顯示介面讓使用者選擇到開機的分割區或是其他資訊
(也有些開機管理程式程式太大,MBR的空間塞不進去,會從MBR中導到某個分割區的boot sector,再從該資訊載入開機管理程式)

5. 而Linux比較特別,可以直接從GRUB直接載入核心,載入作業系統 

解決辦法如下:

————————————————————————–

winXP下的開機資訊修復

放入XP安裝光碟,用它開機

按R進入Recovery Console下打fixmbr修復

或是使用spfdisk的修復MBR功能

A:\>spfdisk /mbr

————————————————————————–

Linux下的開機選單(GRUB)修復

放入你使用的Linux版本的LiveCD,用它開機
在登入到桌面之後,打開命令列

以Fedora 12為例 (GRUB 1版的做法)

(註:以下這段ubuntu就不適用,因為它使用GRUB 2版。做法為另一種)
(該做法不限定在Fedora,Redhat系列的都可以用,像是RHEL,Cent OS … 等等)

先打入fdisk -l查看磁碟分割的狀況

[root@localhost ~]#fdisk -l

Disk /dev/sda: 320.1 GB, 320072933376 bytes
255 heads, 63 sectors/track, 38913 cylinders, total 625142448 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x129dfc88

   Device Boot      Start         End      Blocks   Id  System
/dev/sda1   *          63    18844244     9422091    7  HPFS/NTFS
/dev/sda2        18844245   625137344   303146550    f  W95 Ext’d (LBA)
/dev/sda5        18860310    52516484    16828087+   7  HPFS/NTFS
/dev/sda6        52516548    60918479     4200966   83  Linux
/dev/sda7        60918543    62990864     1036161   82  Linux swap / Solaris
/dev/sda8        62990928    96454259    16731666    7  HPFS/NTFS
/dev/sda9        96454323   625137344   264341511    7  HPFS/NTFS

 

找到Fedora安裝的分割區(ext3或ext4分割,該目錄含有GRUB的資訊)
我的電腦為/dev/sda6

打入grub進入頁面

[root@localhost~]#grub

切換根目錄為Fedora安裝的目錄

grub> root (hd0,5)
root (hd0,5)
 Filesystem type is ext2fs, partition type 0x83

這個時候可能要嘗試一下,大約是在前面查到的sda6的上一號或下一號
出現ext2fs字樣就可以繼續

 

範例1:

寫入開機資訊到該硬碟的MBR

grub> setup (hd0)
setup (hd0)
Checking if “/boot/grub/stage1” exists… no
Checking if “/grub/stage1” exists… yes
Checking if “/grub/stage2” exists… yes
Checking if “/grub/e2fs_stage1_5” exists… yes
Running “embed /grub/e2fs_stage1_5 (hd0)”…  15 sectors are embedded.
succeeded
Running “install /grub/stage1 (hd0) (hd0)1+15 p (hd0,5)/grub/stage2
/grub/grub.conf”… succeeded
Done.

出現類似succeeded字樣就成功了

 

範例2:

寫入開機資訊到Fedora的該分割區的開機磁軌
(我的是sda6,也就是這裡的(hd0,5)每台電腦環境不同,請以你的為主)

grub> setup (hd0,5)
setup (hd0,5)
 Checking if “/boot/grub/stage1” exists… yes
 Checking if “/boot/grub/stage2” exists… yes
 Checking if “/boot/grub/e2fs_stage1_5” exists… yes
 Running “embed /boot/grub/e2fs_stage1_5 (hd0,5)”… failed (this is not fatal)
 Running “embed /boot/grub/e2fs_stage1_5 (hd0,5)”… failed (this is not fatal)
 Running “install /boot/grub/stage1 (hd0,5) /boot/grub/stage2 p /boot/grub/grub.conf “… succeeded
Done.

出現類似succeeded字樣就成功了

————————————————————————–

這篇很簡略的寫出操作的重點

詳細請看

http://linux.vbird.org/linux_basic/0510osloader.php#grub_install

http://bentai.wordpress.com/2006/08/16/%E5%9C%A8windows-xp-sp2%E4%B8%8B%E4%BF%AE%E5%BE%A9mbr/

有趣的語音控制

看到朋友的Facebook感到很有興趣

 想知道電腦是男的還是女的?步驟一:點『開始』,在『所有程式』裡找到『附屬應用程式』,點『記事本』新增一個新記事本文件。步驟二:在裡面輸入 CreateObject(“SAPI.SpVoice”).Speak “I love YOU” 步驟三:另存新檔名為 .VBS 文件如:我愛你.vbs⋯⋯然後,點擊這個文件就會聽到一句I LOVE U。透過聲音就可以辨别你的電腦是男生還是女生

這個真的酷!!!

——————————-

這個其實大家很少使用的微軟語音引擎,XP內建Microsoft Sam
所以大部分是男的只能說英文

Vista或Win7應該有別的引擎,別的廠商也有在做

跟自然輸入法的語音引擎應該不同

在XP下按開始→控制台→語音

就會看到

————————–

在bat底下的代碼

mshta vbscript:CreateObject(“SAPI.SpVoice”).Speak(“I can say english”)(Window.close)

ping 127.0.0.1 /n 2 >nul       rem 這行可以做時間延遲

echo CreateObject(“SAPI.SpVoice”).Speak CreateObject(“Scripting.FileSystemObject”).OpenTextFile(WScript.Arguments(0)).ReadAll>ss.vbs

rem 可以產生一個sss.vbs,把文字檔拖進去,可以閱讀全文

————————–

在vbs底下詳細操作的代碼

set oSa = Createobject(“SAPI.SpVoice”)
oSa.volume=100   ‘音量
oSa.rate=1            ‘講話速率
oSa.speak(“i can say english”) 

————————–

以下是讓C#能夠控制該語音引擎的代碼 

引用:http://social.msdn.microsoft.com/forums/en-US/csharpgeneral/thread/eef2ae7f-6f2c-45be-b25d-abdb74354687

MSDN詳細資料:http://msdn.microsoft.com/en-us/library/ms723602(VS.85).aspx

using SpeechLib;

namespace ConsoleApplication1 {
  class Program {

    static void Main (string [] args) {

      SpVoice voice = new SpVoice ();

      voice.Speak (“A new EXE CAAntiSpyware appeared.”, SpeechVoiceSpeakFlags.SVSFlagsAsync);

      // … add code here if needed…

      voice.WaitUntilDone (30000);

    }

  }
}

[MySQL]更改預設資料庫的編碼

引用:http://www.twvbb.com/vbb/thread/104/9420/

這是MySQL安裝的時候預設的狀況
使用xampp或是linux底下的lampp

 

在phpmyadmin底下的variables可以看到
預設新增的資料庫的編碼會是latin1
但我們通常都會新增utf8的資料庫

請修改MySQL的設定檔my.cnf

(Linux底下)

/etc/my.cnf
或是
/opt/lampp/etc/my.cnf

(XP底下)

 

找到以下標籤並加上紅字部份

[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
init-connect=’SET NAMES utf8′

[client]
default-character-set=utf8

 

資料庫轉換的步驟請參考引用原文
我看完消化過在補

[C#視窗]Ado.net連接Access資料庫的四種方式

//***Access(ODBC Version)
//[OdbcConnection->OdbcDataAdapter->DataSet->dataGridView1]
string strSQL =“Select * from table”;
try
{
IDbConnection dbConn = new System.Data.Odbc.OdbcConnection(@”Driver={Microsoft Access Driver (*.mdb)};DBQ=|DataDirectory|\database.mdb”);
dbConn.Open();
IDbDataAdapter dbAdapter = new System.Data.Odbc.OdbcDataAdapter(strSQL, (System.Data.Odbc.OdbcConnection)dbConn);
System.Data.DataSet dbSet = new System.Data.DataSet();
dbAdapter.Fill(dbSet);
dataGridView1.DataSource = dbSet.Tables[0];
}
catch (System.Data.Odbc.OdbcException ex)
{
MessageBox.Show(ex.ToString());
}
//***Access(ODBC Version)
//[OdbcConnection->OdbcCommand->DataTable->dataGridView1]
int i;
System.Data.DataTable dt = new DataTable();
System.Data.DataRow dr;
string strSQL =“Select * from table”;
try
{
IDbConnection dbConn = new System.Data.Odbc.OdbcConnection(@”Driver={Microsoft Access Driver (*.mdb)};DBQ=|DataDirectory|\database.mdb”);
dbConn.Open();
IDbCommand dbCommand = new System.Data.Odbc.OdbcCommand(strSQL, (System.Data.Odbc.OdbcConnection)dbConn);
IDataReader dbReader = dbCommand.ExecuteReader();
//
for (i = 0; i < dbReader.FieldCount; i++)
dt.Columns.Add(newDataColumn(dbReader.GetName(i)));
//
while (dbReader.Read())
{
dr = dt.NewRow();
for (i = 0; i < dbReader.FieldCount; i++)
dr[i] = dbReader[i];
dt.Rows.Add(dr);
}
}
catch (System.Data.Odbc.OdbcException ex)
{
MessageBox.Show(ex.ToString());
}
dataGridView1.DataSource = dt;
//***Access(OleDB Version)
//[OleDbConnection->OleDbDataAdapter->DataSet->dataGridView1]
string strSQL=“Select * from table”;
try
{
IDbConnection dbConn = new System.Data.OleDb.OleDbConnection(@”Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\database.mdb;Persist Security Info=True”);
IDbDataAdapter dbAdapter = new System.Data.OleDb.OleDbDataAdapter(strSQL, (System.Data.OleDb.OleDbConnection)dbConn);
System.Data.DataSet dbSet = new System.Data.DataSet();
dbAdapter.Fill(dbSet);
dataGridView1.AutoGenerateColumns = true;
dataGridView1.DataSource = dbSet.Tables[0];
}
catch (System.Data.OleDb.OleDbException ex)
{
MessageBox.Show(ex.ToString());
}
//***Access(OleDB Version)
//[OleDbConnection->OleDbCommand->DataTable->dataGridView1]
int i;
System.Data.DataTable dt = new DataTable();
System.Data.DataRow dr;
string strSQL =“Select * from table”;
try
{
IDbConnection dbConn = new System.Data.OleDb.OleDbConnection(@”Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\database.mdb;Persist Security Info=True”);
dbConn.Open();
IDbCommand dbCommand = new System.Data.OleDb.OleDbCommand(strSQL, (System.Data.OleDb.OleDbConnection)dbConn);
IDataReader dbReader = dbCommand.ExecuteReader();
//
for (i = 0; i < dbReader.FieldCount; i++)
dt.Columns.Add(newDataColumn(dbReader.GetName(i)));
//
while (dbReader.Read())
{
dr = dt.NewRow();
for (i = 0; i < dbReader.FieldCount; i++)
dr[i] = dbReader[i];
dt.Rows.Add(dr);
}
}
catch (System.Data.Odbc.OdbcException ex)
{
MessageBox.Show(ex.ToString());
}
dataGridView1.DataSource = dt;