$row[1],這樣以數(shù)組下標來讀取數(shù)據(jù),而mysql_fetch_array()返回的數(shù)組既包含第一種,也包含鍵值
對的形式,我們可以這樣讀取數(shù)據(jù),(假如數(shù)據(jù)庫的字段是 username,passwd):
$row['username'], $row['passwd']
而且,如果用($row as $kay => $value)來操作的話,還以直接取得數(shù)據(jù)庫的字段名稱。
更主要的是mysqli是php5提供的新函數(shù)庫,(i)表示改進,其執(zhí)行速度更快.
例如:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
<?php //連接到本地mysql數(shù)據(jù)庫,選擇test為操作庫 $mysqli = mysqli_connect( "localhost" , "root" , "" , "test" , 3306); //用mysql_query函數(shù)從user表里讀取數(shù)據(jù) $result = mysqli_query( $mysqli , "SELECT * FROM userinfo" ); while ( $row = mysqli_fetch_array( $result )) //通過循環(huán)讀取數(shù)據(jù)內(nèi)容 { ?> <tr> <td align= "center" height= "19" ><?php echo $row [ "ID" ]?></td> <td align= "center" ><?php echo $row [ "Name" ]?></td> <td align= "center" ><?php echo $row [ "Detail" ]?></td> </tr> <?php } //關(guān)閉對數(shù)據(jù)庫的連接 mysqli_free_result( $result ); mysqli_close( $mysqli );*/ ?> |
mysql_fetch_array --從結(jié)果集中取得一行作為關(guān)聯(lián)數(shù)組,或數(shù)字數(shù)組,或二者兼有
說明array mysql_fetch_array ( resource result [, int result_type])
返回根據(jù)從結(jié)果集取得的行生成的數(shù)組,如果沒有更多行則返回 FALSE。
mysql_fetch_array() 是 mysql_fetch_row() 的擴展版本。除了將數(shù)據(jù)以數(shù)字索引方式儲存在數(shù)組中之外,還可以將數(shù)據(jù)作為關(guān)聯(lián)索引儲存,用字段名作為鍵名。
如果結(jié)果中的兩個或以上的列具有相同字段名,最后一列將優(yōu)先。要訪問同名的其它列,必須用該列的數(shù)字索引或給該列起個別名。對有別名的列,不能再用原來的列名訪問其內(nèi)容(本例中的 'field')。
例子 1. 相同字段名的查詢
select table1.field as foo, table2.field as bar from table1, table2
有一點很重要必須指出,用 mysql_fetch_array() 并不明顯 比用 mysql_fetch_row() 慢,而且還提供了明顯更多的值。
mysql_fetch_array() 中可選的第二個參數(shù) result_type 是一個常量,可以接受以下值:MYSQL_ASSOC,MYSQL_NUM 和 MYSQL_BOTH。本特性是 PHP 3.0.7 起新加的。本參數(shù)的默認值是 MYSQL_BOTH。
如果用了 MYSQL_BOTH,將得到一個同時包含關(guān)聯(lián)和數(shù)字索引的數(shù)組。用 MYSQL_ASSOC 只得到關(guān)聯(lián)索引(如同 mysql_fetch_assoc()那樣),用 MYSQL_NUM 只得到數(shù)字索引(如同 mysql_fetch_row()那樣)。
注: 該函數(shù)返回的字段名是大小寫敏感的。
例子 2. mysql_fetch_array 使用 MYSQL_NUM
1
2
3
4
5
6
7
8
9
10
11
12
13
|
<?php mysql_connect( "localhost" , "mysql_user" , "mysql_password" ) or die ( "Could not connect: " . mysql_error()); mysql_select_db( "mydb" ); $result = mysql_query( "SELECT id, name FROM mytable" ); while ( $row = mysql_fetch_array( $result , MYSQL_NUM)) { printf ( "ID: %s Name: %s" , $row [0], $row [1]); } mysql_free_result( $result ); ?> |
例子 3. mysql_fetch_array 使用 MYSQL_ASSOC
1
2
3
4
5
6
7
8
9
10
11
12
|
<?php mysql_connect( "localhost" , "mysql_user" , "mysql_password" ) or die ( "Could not connect: " . mysql_error()); mysql_select_db( "mydb" ); $result = mysql_query( "SELECT id, name FROM mytable" ); while ( $row = mysql_fetch_array( $result , MYSQL_ASSOC)) { printf ( "ID: %s Name: %s" , $row [ "id" ], $row [ "name" ]); } mysql_free_result( $result ); ?> |
例子 4. mysql_fetch_array 使用 MYSQL_BOTH
1
2
3
4
5
6
7
8
9
10
11
12
|
<?php mysql_connect( "localhost" , "mysql_user" , "mysql_password" ) or die ( "Could not connect: " . mysql_error()); mysql_select_db( "mydb" ); $result = mysql_query( "SELECT id, name FROM mytable" ); while ( $row = mysql_fetch_array( $result , MYSQL_BOTH)) { printf ( "ID: %s Name: %s" , $row [0], $row [ "name" ]); } mysql_free_result( $result ); ?> |
參見 mysql_fetch_row() 和 mysql_fetch_assoc
mysql_fetch_row -- 從結(jié)果集中取得一行作為枚舉數(shù)組
說明
array mysql_fetch_row ( resource result)
返回根據(jù)所取得的行生成的數(shù)組,如果沒有更多行則返回 FALSE。
mysql_fetch_row() 從和指定的結(jié)果標識關(guān)聯(lián)的結(jié)果集中取得一行數(shù)據(jù)并作為數(shù)組返回。每個結(jié)果的列儲存在一個數(shù)組的單元中,偏移量從 0 開始。
依次調(diào)用 mysql_fetch_row() 將返回結(jié)果集中的下一行,如果沒有更多行則返回 FALSE。