1. 建立和關閉串連
1) mysql_connect()
resource mysql_connect([string hostname [:port][:/path/to/socket][,string username] [,string password]])
所有參數都是可選的
舉例:
@mysql_connect(“localhost”, “user”, “password”)
or die(“Could not connect to mysql server!”);
注意,@符號表示禁止失敗嘗試導致的任何錯誤資訊,使用者將看到的是die()中指定的錯誤資訊.
注意,當與多個mysql進行串連時,必須指定每個串連的連結ID,如下:
$link1 = @mysql_connect(“server1″, “user”, “password”)
or die(“Could not connect to mysql server!”);
$link2 = @mysql_connect(“server2″, “user”, “password”)
or die(“Could not connect to mysql server!”);
2) mysql_pconnect()
resource mysql_pconnect([string hostname [:port][:/path/to/socket][,string username] [,string password]])
與mysql_connect()不同的是:會首先尋找現有連結,不存在時才建立.
注意,不需要顯示關閉串連(mysql_close()),因為串連將放在池中,所以叫持久串連.
3) mysql_close()
boolean mysql_close([resource link_id])
關閉串連不是必須的,因為可以由mysql的記憶體回收來處理.
如果沒有指定link_id,則關閉最近的連結.
2. 選擇資料庫
mysql_select_db()
boolean mysql_select_db(string db_name [, resource link_id])
3. 查詢MySql
1) mysql_query()
resource mysql_query(string query [,resource link_id])
負責執行query.
2) mysql_db_query()
resource mysql_db_query(string database, string query [, resource link_id])
等價於mysql_select_db() + mysql_query(),從參數中就可以清楚的看出來.
4. 擷取和顯示資料
1) mysql_result()
mixed mysql_result(resource result_set, int row [,mixed field])
從result_set 的指定row 中擷取一個field 的資料. 簡單但是效率低.
舉例:
複製代碼 代碼如下:$link1 = @mysql_connect(“server1″, “webuser”, “password”)
or die(“Could not connect to mysql server!”);
@mysql_select_db(“company”) or die(“Could not select database!”);
$query = “select id, name from product order by name”;
$result = mysql_query($query);
$id = mysql_result($result, 0, “id”);
$name = mysql_result($result, 0, “name”);
mysql_close();
注意,上述代碼只是輸出結果集中的第一條資料的欄位值,如果要輸出所有記錄,需要迴圈處理. 複製代碼 代碼如下:…
for ($i = 0; $i <= mysql_num_rows($result); $i++)
{
$id = mysql_result($result, 0, “id”);
$name = mysql_result($result, 0, “name”);
echo “Product: $name ($id)”;
}
…
注意,如果查詢欄位名是別名,則mysql_result中就使用別名.
2) mysql_fetch_row()
array mysql_fetch_row(resource result_set)
從result_set中擷取整行,把資料放入數組中.
舉例(注意和list 的巧妙配合): 複製代碼 代碼如下:…
$query = “select id, name from product order by name”;
$result = mysql_query($query);
while(list($id, $name) = mysql_fetch_row($result)) {
echo “Product: $name ($id)”;
}
…
3) mysql_fetch_array()
array mysql_fetch_array(resource result_set [,int result_type])
mysql_fetch_row()的增強版.
將result_set的每一行擷取為一個關聯陣列或/和數值索引數組.
預設擷取兩種數組,result_type可以設定:
MYSQL_ASSOC:返回關聯陣列,欄位名=>欄位值
MYSQL_NUM:返回數值索引數組.
MYSQL_BOTH:擷取兩種數組.因此每個欄位可以按索引位移引用,也可以按欄位名引用.
舉例: 複製代碼 代碼如下:…
$query = “select id, name from product order by name”;
$result = mysql_query($query);
while($row = mysql_fetch_array($result, MYSQL_BOTH)) {
$name = $row['name'];//或者 $name = $row[1];
$name = $row['id'];//或者 $name = $row[0];
echo “Product: $name ($id)”;
}
…
4) mysql_fetch_assoc()
array mysql_fetch_assoc(resource result_set)
相當於 mysql_fetch_array($result, MYSQL_ASSOC)
5) mysql_fetch_object()
object mysql_fetch_object(resource result_set)
和mysql_fetch_array()功能一樣,不過返回的不是數組,而是一個對象.
舉例: 複製代碼 代碼如下:…
$query = “select id, name from product order by name”;
$result = mysql_query($query);
while($row = mysql_fetch_object($result)) {
$name = $row->name;
$name = $row->id;
echo “Product: $name ($id)”;
}
…
5. 所選擇的記錄和受影響的記錄
1) mysql_num_rows()
int mysql_num_rows(resource result_set)
返回result_set中的行數.
注意,mysql_num_rows()只在確定select語句查詢獲得的記錄數有效,如果要擷取insert/updata/delete查詢影響的記錄數,需要使用mysql_affected_rows().
2) mysql_affected_rows()
int mysql_affected_rows([resource link_id])
擷取insert/updata/delete查詢影響的記錄數
注意,不需要輸入參數,預設使用最近建立的資料庫連接的最近結果.可以使用選擇性參數link_id來選擇資料庫連接.
6. 擷取資料庫和表的資訊
1) mysql_list_dbs()
resource mysql_list_dbs([resource link_id])
擷取伺服器上所有資料庫名稱.
舉例: 複製代碼 代碼如下:mysql_connect(“localhost”, “name”,”pwd”);
$dbs = mysql_list_dbs();
while (list($db) = mysql_fetch_row(dbs)) {
echo “$db <br>”;
}
注意,輸出結果與使用的使用者權限相關.
2) mysql_db_name()
string mysql_db_name(resource result_set, interger index)
擷取在mysql_list_dbs()返回的result_set中位置為index的資料庫名.
3) mysql_list_tables()
resource mysql_list_tables(string database [,resource link_id])
擷取database中的所有表名.
4) mysql_tablename()
string mysql_tablename(resource result_set, interger index)
擷取mysql_list_tables()返回的result_set中位置為index的表名.
在學習PHP的COM 和 .Net(Windows)函數的時候,發現了一個通過COM操作SQL SERVER的例子,尋找了相關的資料,於是就有了這篇PHP串連ACCESS的文章,相信網上已經很多了,還是貼在這裡吧。
我的機器環境:WIN2000,APACHE2,PHP Version 5.1.0RC1 複製代碼 代碼如下:<?php
$conn = new COM(“ADODB.Connection”) or die(“Cannot start ADODB.Connection”);
$conn->Open(“Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\\php5\\netBook.mdb”);
$rs = $conn->Execute(“select * from manage”); // 記錄集
$num_columns = $rs->Fields->Count();
echo $num_columns . “<br />\n”;
for ($i=0; $i < $num_columns; $i++) {
$fld[$i] = $rs->Fields($i);
}
$rowcount = 0;
while (!$rs->EOF) {
for ($i=0; $i < $num_columns; $i++)
{
echo htmlspecialchars($fld[$i]->value) . “\t”;
}
echo “<br />\n”;
$rowcount++; // rowcount 自增
$rs->MoveNext();
}
$rs->Close(); //關閉資料集
$conn->Close();
?>