註冊
登錄
首頁
論壇版規
禁止列表
說明
地圖
數位書香
私人消息 (0)
公共消息 (0)
論壇任務 (0)
系統消息 (0)
好友消息 (0)
帖子消息 (0)
麻辣家族討論版版
»
PHP
»
PHP+MySQL 入門實作
» 8-1-3 資料錄位置變換
返回列表
下一主題
上一主題
發帖
8-1-3 資料錄位置變換
小誌
發短消息
加為好友
小誌
(小誌)
當前離線
曾經也是水電工
UID
9
帖子
1195
主題
395
精華
113
積分
1747
金錢
1747
點名
0
作業系統
Vista
軟體版本
Office 2003
閱讀權限
200
性別
男
來自
台灣
在線時間
491 小時
註冊時間
2010-5-1
最後登錄
2025-5-11
暱稱:
小誌
頭銜:
曾經也是水電工
管理員
帖子
1195
主題
395
精華
113
積分
1747
點名
0
作業系統
Vista
軟體版本
Office 2003
閱讀權限
200
性別
男
來自
台灣
註冊時間
2010-5-1
最後登錄
2025-5-11
1
#
跳轉到
»
倒序看帖
打印
字體大小:
t
T
發表於 2011-4-20 10:11
|
只看該作者
8-1-3 資料錄位置變換
8-1-3 資料錄位置變換
在上一小節中,我們已知道:利用「mysql_featch_array()」
函數
取得一筆資料錄資料後,則「作用中」的資料錄位置會自動移到下一筆尚未提取資料的資料錄位置上,其實還有一個快速變換作用中資料錄位置的函數:mysql_data_seek():
mysql_data_seek() 函數
int mysql_data_seek ( int result_identifier, int row_number)
複製
代碼
result_identifier、row_number都是必要參數,result_identifier參數值可為mysql_db_query()、mysql_query()、mysql_list_tables()、mysql_list_dbs()等函數所回傳的結果ID。
當變換作用中資料錄位置成功回傳true值,反之,回傳false值;例如,快速變換作用中資料錄位置到第一筆資料錄上:
$datalist=mysql_query($
SQL
);
mysql_data_seek($datalist,0);
複製代碼
請注意:資料錄的位置編號是從0開始!
若我們想知到共有多少筆資料記錄可提取,則「mysql_num_rows()」函數可以告訴我們:
mysql_num_rows() 函數
int mysql_num_rows ( int result_ identifier)
複製代碼
result_identifier是必要參數,參數值可為mysql_db_query()、mysql_query()、mysql_list_tables()、mysql_list_dbs()等函數所回傳的結果ID。
例如:
//
資料庫
存在,建立SQL命令字串
$SQL="SELECT * FROM transcript";
//將回傳結果存放於
變數
中
$datalist=mysql_query($SQL);
//取得資料錄筆數
$x=mysql_num_rows($datalist);
echo "共 $X 筆資料記錄";
複製代碼
樓主熱帖
論壇不讓資歷比較淺的人下載查看附件的用意
EXCEL專屬討論區自即日起限中學生以上會員方
麻辣家族討論區 通用版規
OFFICE 基礎教學數位化
ATX 電源供應器手動啟動(不接主機板啟動)
考慮關閉論壇網站
麻辣家族討論區隱私權政策說明
麻辣家族討論區 誠徵版主
由舊論壇轉進的中學生等級以上會員,請關注!
14-2 資料庫圖片存取
收藏
分享
心安,平安
發表任何無意義的感謝或灌水文章一律砍,珍惜帳號,請詳閱版規!!
小誌
發短消息
加為好友
小誌
(小誌)
當前離線
曾經也是水電工
UID
9
帖子
1195
主題
395
精華
113
積分
1747
金錢
1747
點名
0
作業系統
Vista
軟體版本
Office 2003
閱讀權限
200
性別
男
來自
台灣
在線時間
491 小時
註冊時間
2010-5-1
最後登錄
2025-5-11
暱稱:
小誌
頭銜:
曾經也是水電工
管理員
帖子
1195
主題
395
精華
113
積分
1747
點名
0
作業系統
Vista
軟體版本
Office 2003
閱讀權限
200
性別
男
來自
台灣
註冊時間
2010-5-1
最後登錄
2025-5-11
2
#
發表於 2011-4-20 10:11
|
只看該作者
以範例ex08_06.php為例,我們可利用上述兩函數修改如下,讓程式只列印出1,3,5…等單數編號的資料錄(範例ex08_07.php):
ex08_07.php
<?
$conn = mysql_connect("localhost", "root", "12345a");
if(@mysql_select_db("STUDENTS", $conn))
{
//指定提取資料的校對字元表
mysql_query("set character set big5");
//資料庫存在,建立SQL命令字串
$SQL="SELECT * FROM transcript";
//將回傳結果存放於變數中
$datalist=mysql_query($SQL);
//取得欄位數量
$fieldnum=mysql_num_fields($datalist);
?>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=big5">
<title>範例ex08_07</title>
</head>
<center><table border=1 width=100%>
<?
/**************列出欄位抬頭***************/
echo "<tr>";
for ($x=0 ;$x<$fieldnum;$x++)
{
echo "<td>" . mysql_field_name($datalist,$x) . "</td>";
}
echo "</tr>";
/**************列出欄位資料***************/
//取得資料錄數量
$rowsnum=mysql_num_rows($datalist);
for ($y=0;$y<$rowsnum;$y+=2)
{
if($y<=$rowsnum):
//變換作用中資料錄位置
mysql_data_seek($datalist,$y);
//將資料錄轉換為欄位陣列集合
$fielddatas=mysql_fetch_array($datalist);
//輸出欄位資料
echo "<tr>";
for ($x=0;$x<$fieldnum;$x++)
{
echo "<td>" . $fielddatas[$x] . "</td>";
}
echo "</tr>";
endif;
}
?>
<table></body>
</html>
<?
}
else
{
echo "資料庫不存在";
}
?>
複製代碼
心安,平安
發表任何無意義的感謝或灌水文章一律砍,珍惜帳號,請詳閱版規!!
TOP
靜思自在 :
閒人無樂趣,忙人無是非。
返回列表
下一主題
上一主題
EXCEL專屬討論區
Excelㄧ般區
Excel程式區
進階應用專區
OFFICE 系列
Word
PowerPoint
Access
Office不分區
程式語言
VB 與 VB.Net
C 與 C#
Java 與 J#
程式設計不分區
資料庫
ORACLE
My SQL
MS SQL
網頁設計
ASP 與 ASP.NET
PHP
PHP+MySQL 入門實作
JavaScript
FLASH / ActionScript
HTM/ HTML/ CSS
網頁設計不分區
電腦與作業系統
電腦各種硬體討論
一般電腦軟體討論
論壇事務
管理公告
投訴反映
新手測試
愛 ‧ 生活
公益佈告欄
生活與感動
[收藏此主題]
[關注此主題的新回復]
[通過 QQ、MSN 分享給朋友]
申請友情鏈接
Facebook粉絲