本文目錄一覽:
- 1、php里=&是什麼意思
- 2、PHP基於單例模式實現的數據庫操作基類
- 3、php中靜態方法的問題
- 4、求PHP大神,如圖調用getInstance()方法的時候,他是以怎樣的形式以$class_name,為鍵值,
php里=&是什麼意思
這是引用賦值,應該注意的是 = 不是一個運算符,不能看成一個整體。
而 XoopsPreload::getInstance() 應該看成一個整體,相當於把XoopsPreload::getInstance()的引用賦值給$xoopsPreload,也就是變量$xoopsPreload是類XoopsPreload實例的一個別名,改變變量$xoopsPreload的值將會改變類XoopsPreload的內部值,這應該是一個單例吧。
PHP基於單例模式實現的數據庫操作基類
本文實例講述了PHP基於單例模式實現的數據庫操作基類。分享給大家供大家參考,具體如下:
配置文件:
?php
$db
=
array(
‘host’=’localhost’,
‘user’=’root’,
‘password’=”,
‘database’=’test’,
)
?
php
數據庫基類:
?php
class
db
{
public
$conn;
public
static
$sql;
public
static
$instance=null;
private
function
__construct(){
require_once(‘db.config.php’);
$this-conn
=
mysql_connect($db[‘host’],$db[‘user’],$db[‘password’]);
if(!mysql_select_db($db[‘database’],$this-conn)){
echo
“失敗”;
};
mysql_query(‘set
names
utf8′,$this-conn);
}
public
static
function
getInstance(){
if(is_null(self::$instance)){
self::$instance
=
new
db;
}
return
self::$instance;
}
/**
*
查詢數據庫
*/
public
function
select($table,$condition=array(),$field
=
array()){
$where=”;
if(!empty($condition)){
foreach($condition
as
$k=$v){
$where.=$k.”='”.$v.”‘
and
“;
}
$where=’where
‘.$where
.’1=1′;
}
$fieldstr
=
”;
if(!empty($field)){
foreach($field
as
$k=$v){
$fieldstr.=
$v.’,’;
}
$fieldstr
=
rtrim($fieldstr,’,’);
}else{
$fieldstr
=
‘*’;
}
self::$sql
=
“select
{$fieldstr}
from
{$table}
{$where}”;
$result=mysql_query(self::$sql,$this-conn);
$resuleRow
=
array();
$i
=
0;
while($row=mysql_fetch_assoc($result)){
foreach($row
as
$k=$v){
$resuleRow[$i][$k]
=
$v;
}
$i++;
}
return
$resuleRow;
}
/**
*
添加一條記錄
*/
public
function
insert($table,$data){
$values
=
”;
$datas
=
”;
foreach($data
as
$k=$v){
$values.=$k.’,’;
$datas.=”‘$v'”.’,’;
}
$values
=
rtrim($values,’,’);
$datas
=
rtrim($datas,’,’);
self::$sql
=
“INSERT
INTO
{$table}
({$values})
VALUES
({$datas})”;
if(mysql_query(self::$sql)){
return
mysql_insert_id();
}else{
return
false;
};
}
/**
*
修改一條記錄
*/
public
function
update($table,$data,$condition=array()){
$where=”;
if(!empty($condition)){
foreach($condition
as
$k=$v){
$where.=$k.”='”.$v.”‘
and
“;
}
$where=’where
‘.$where
.’1=1′;
}
$updatastr
=
”;
if(!empty($data)){
foreach($data
as
$k=$v){
$updatastr.=
$k.”='”.$v.”‘,”;
}
$updatastr
=
‘set
‘.rtrim($updatastr,’,’);
}
self::$sql
=
“update
{$table}
{$updatastr}
{$where}”;
return
mysql_query(self::$sql);
}
/**
*
刪除記錄
*/
public
function
delete($table,$condition){
$where=”;
if(!empty($condition)){
foreach($condition
as
$k=$v){
$where.=$k.”='”.$v.”‘
and
“;
}
$where=’where
‘.$where
.’1=1′;
}
self::$sql
=
“delete
from
{$table}
{$where}”;
return
mysql_query(self::$sql);
}
public
static
function
getLastSql(){
echo
self::$sql;
}
}
$db
=
db::getInstance();
//$list
=
$db-select(‘demo’,array(‘name’=’tom’,’password’=’ds’),array(‘name’,’password’));
//echo
$db-insert(‘demo’,array(‘name’=’腳本之家’,’password’=’123′));
//echo
$db-update(‘demo’,array(“name”=’xxx’,”password”=’123′),array(‘id’=1));
echo
$db-delete(‘demo’,array(‘id’=’2’));
db::getLastSql();
echo
“pre”;
?
更多關於PHP操作數據庫相關內容感興趣的讀者可查看本站專題:《php+mysql數據庫操作入門教程》、《PHP基於pdo操作數據庫技巧總結》及《php常見數據庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
php中靜態方法的問題
樓上說的差不多
但從理解的角度
self是類內部默認的類名
new self()就是new classname()
這樣應該比較好理解
對於靜態方法的理解一樣,我們在調用靜態類的時候用的是classname::function()
那self就是類內部自己的調用classname::function()
代替了一個類名的變量
不在類內部,它也就不可能知道自己是誰
求PHP大神,如圖調用getInstance()方法的時候,他是以怎樣的形式以$class_name,為鍵值,
$class_name 是傳入的 字符串啊,如代碼中的 ‘Mysqldb’和 ‘student’
原創文章,作者:MVJC,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/135621.html