PHP向MySQL資料庫中寫入資料有三個步驟:
1,PHP和MySQL建立串連關係
2,開啟MySQL資料庫
3,接受頁面資料,PHP錄入到指定的表中
1、2兩步可直接使用一個資料庫連結檔案即可:conn.php
代碼如下 |
複製代碼 |
<?php mysql_connect("localhost","root","");//串連MySQL mysql_select_db("hello");//選擇資料庫 ?> |
當然,前提是已經安裝WEB伺服器、PHP和MySQL,並且建立MySQL表“cnbruce”
mysql_connect()中三個參數分別為MySQL地址、MySQL使用者名稱和MySQL密碼
然後就是通過WEB頁面傳遞資料,讓PHP通過SQL語句將資料寫入MySQL資料庫指定的表中,比如建立檔案 post.php
代碼如下 |
複製代碼 |
<?php require_once("conn.php");//引用資料庫連結檔案 $uname = $_GET['n'];//GET方法為URL參數傳遞 $psw = $_GET['p']; $psw=md5($psw);//直接使用MD5加密 $sql = "insert into members(username,password) values ('$uname','$psw')"; mysql_query($sql);//借SQL語句插入資料 mysql_close();//關閉MySQL串連 echo "成功錄入資料"; ?> |
測試頁面: http://localhost/post.php?n=cnbruce&p=i0514
即可向MySQL資料庫hello的members表中插入新的資料“cnbruce”到username欄位、“i0514”到password欄位
補充:讀取表
讀取表中的內容,這裡我們用while,可以根據具體情況,用for 或其他的.
代碼如下 |
複製代碼 |
while($row = mysql_fetch_array($result)) { echo "<div style="height:24px; line-height:24px; font-weight:bold;">"; //排版代碼 echo $row['Topic'] . "<br/>"; echo "</div>"; //排版代碼 } |
上面是接受的post例子
代碼如下 |
複製代碼 |
<?php $con=mysql_connect("localhost","root","gl"); mysql_select_db("happysea"); $name=$_POST['name']; $password=$_POST['password']; $sex=$_POST['sex']; $e_mail=$_POST['e_mail']; $question=$_POST['question']; $answer=$_POST['answer']; $sql="insert into userinfo(name,password,sex,e_mail,question,answer) values('$name','$password','$sex','$e_mail','$question','$answer')"; if(!$sql) { echo('註冊失敗!'); } else { echo('註冊成功!'); } ?> 這是資料庫。 mysql> describe userinfo; +----------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +----------+-------------+------+-----+---------+----------------+ | id | int(11) | NO | PRI | NULL | auto_increment | | name | text | YES | | NULL | | | password | varchar(20) | YES | | NULL | | | sex | char(4) | YES | | NULL | | | e_mail | varchar(30) | YES | | NULL | | | question | text | YES | | NULL | | | answer | text | YES | | NULL | | +----------+-------------+------+-----+---------+----------------+ |