PHP向MySQL數(shù)據(jù)庫中寫入數(shù)據(jù)有三個步驟:
創(chuàng)新互聯(lián)建站專注骨干網絡服務器租用十余年,服務更有保障!服務器租用,西部信息中心 成都服務器租用,成都服務器托管,骨干網絡帶寬,享受低延遲,高速訪問。靈活、實現(xiàn)低成本的共享或公網數(shù)據(jù)中心高速帶寬的專屬高性能服務器。
1,PHP和MySQL建立連接關系
2,打開MySQL數(shù)據(jù)庫
3,接受頁面數(shù)據(jù),PHP錄入到指定的表中
1、2兩步可直接使用一個數(shù)據(jù)庫鏈接文件即可:conn.php
代碼如下
?php
mysql_connect("localhost","root","");//連接MySQL
mysql_select_db("hello");//選擇數(shù)據(jù)庫
?
當然,前提是已經安裝WEB服務器、PHP和MySQL,并且建立MySQL表“cnbruce”
mysql_connect()中三個參數(shù)分別為MySQL地址、MySQL用戶名和MySQL密碼
然后就是通過WEB頁面?zhèn)鬟f數(shù)據(jù),讓PHP通過SQL語句將數(shù)據(jù)寫入MySQL數(shù)據(jù)庫指定的表中,比如新建文件 post.php
代碼如下
?php
require_once("conn.php");//引用數(shù)據(jù)庫鏈接文件
$uname = $_GET['n'];//GET方法為URL參數(shù)傳遞
$psw = $_GET['p'];
$psw=md5($psw);//直接使用MD5加密
$sql = "insert into members(username,password) values ('$uname','$psw')";
mysql_query($sql);//借SQL語句插入數(shù)據(jù)
mysql_close();//關閉MySQL連接
echo "成功錄入數(shù)據(jù)";
?
測試頁面: ;p=i0514
即可向MySQL數(shù)據(jù)庫hello的members表中插入新的數(shù)據(jù)“cnbruce”到username字段、“i0514”到password字段
補充:讀取表
讀取表中的內容,這里我們用while,可以根據(jù)具體情況,用for 或其他的.
代碼如下
while($row = mysql_fetch_array($result))
{
echo "div style="height:24px; line-height:24px; font-weight:bold;""; //排版代碼
echo $row['Topic'] . "br/";
echo "/div"; //排版代碼
本身這就是一個自定義函數(shù),數(shù)據(jù)需要插入的話需要自己構造sql語句然后通過mysql_query將函數(shù)返回的值寫入數(shù)據(jù)庫。
想直接讓數(shù)據(jù)庫調用PHP的自定義函數(shù)是不現(xiàn)實的!
需要PHP基礎知識和數(shù)據(jù)庫基礎知識。
以SQL為例。使用PHP MySQL 函數(shù)可以編輯數(shù)據(jù)庫。
mysql_connect() 函數(shù)打開MySQL 連接。舉例
?php
$con = mysql_connect("localhost","mysql_user","mysql_pwd");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}// 一些代碼...mysql_close($con);
?
mysql_connect()三個參數(shù)分別是服務器名,連接賬號,連接密碼。
連接之后,可以使用mysql_select_db()設置要處理的數(shù)據(jù)庫,后面則是用數(shù)據(jù)庫語句處理數(shù)據(jù)。SQL語法簡介網頁鏈接
8.4.4 Model類
getModelName() 獲取當前Model的名稱
getTableName() 獲取當前Model的數(shù)據(jù)表名稱
switchModel(type,vars=array()) 動態(tài)切換模型
table() 設置當前操作的數(shù)據(jù)表
field() 設置要查詢的數(shù)據(jù)字段
where() 設置查詢或者操作條件
data(data) 設置數(shù)據(jù)對象
order(order) 設置排序
limit(limit) 查詢限制
page(page) 查詢分頁
join(join) 進行JOIN查詢
having(having) 進行having查詢
group(group) 進行group查詢
lock(lock) 查詢鎖定
distinct(distinct) 唯一性查詢
count(field) 記錄統(tǒng)計
sum(field) 總數(shù)查詢
min(field) 最小值查詢
max(field) 最大值查詢
avg(field) 平均值查詢
_initialize() 模型初始化方法
_facade(data) 對保存到數(shù)據(jù)庫的數(shù)據(jù)進行處理
_before_write(data) 寫入數(shù)據(jù)前的回調方法 包括新增和更新
add(data='',options=array()) 新增數(shù)據(jù)
_before_insert(data,options) 寫入數(shù)據(jù)前的回調方法
_after_insert(data,options) 寫入數(shù)據(jù)后的回調方法
selectAdd(fields='',table='',options=array()) 通過Select方式添加記錄
save(data='',options=array()) 更新數(shù)據(jù)到數(shù)據(jù)庫
_before_update(data,options) 更新數(shù)據(jù)前的回調方法
_after_update(data,options) 更新成功后的回調方法
delete(options=array()) 刪除數(shù)據(jù)
_after_delete(data,options) 刪除成功后的回調方法
select(options=array()) 查詢數(shù)據(jù)集
_after_select(resultSet,options) 查詢成功后的回調方法
findAll(options=array()) select方法的別名
_options_filter(options) 表達式過濾回調方法
find(options=array()) 查詢數(shù)據(jù)
_after_find(result,options) 查詢成功的回調方法
setField(field,value,condition='') 設置記錄的某個字段值
setInc(field,condition='',step=1) 字段值增長
setDec(field,condition='',step=1) 字段值減少
getField(field,condition='',sepa=' ') 獲取某個字段值
create(data='',type='') 創(chuàng)建數(shù)據(jù)對象
autoCheckToken(data) 表單令牌驗證
query(sql) 執(zhí)行原生SQL查詢
execute(sql='') 執(zhí)行原生SQL操作
startTrans() 啟動事務
commit() 提交事務
rollback() 事務回滾
getError() 獲取模型的錯誤信息
getDbError() 獲取數(shù)據(jù)庫的錯誤信息
getLastInsID() 獲取最后執(zhí)行的SQL語句
getPk() 獲取主鍵名稱
getDbFields() 獲取數(shù)據(jù)表的字段信息
regex(value,rule) 使用正則驗證數(shù)據(jù)
setProperty(name,value) 設置模型的屬性值
2.1版新增方法:
db(linkNum,config='') 切換當前數(shù)據(jù)庫連接
高級模型類AdvModel
topN(count,options=array()) 查詢滿足條件的前N個記錄
getN(position=0,options=array()) 查詢符合條件的第N條記錄
0 表示第一條記錄 -1 表示最后一條記錄
first(options=array()) 獲取滿足條件的第一條記錄
last(options=array()) 獲取滿足條件的最后一條記錄
returnResult(data,type='') 返回指定的數(shù)據(jù)類型
setLazyInc(field,condition='',step=1,lazyTime=0) 字段值延遲增長
setLazyDec(field,condition='',step=1,lazyTime=0) 字段值延遲減少
addConnect(config,linkNum=NULL) 增加數(shù)據(jù)庫連接
delConnect(linkNum) 刪除數(shù)據(jù)庫連接
closeConnect(linkNum) 關閉數(shù)據(jù)庫連接
switchConnect(linkNum,name='') 切換數(shù)據(jù)庫連接
patchQuery(sql=array()) 批處理執(zhí)行SQL語句
getPartitionTableName(data=array()) 得到分表的的數(shù)據(jù)表名