php数据库单例 PHP常用的数据库是

单例模式 数据库 php 怎么用

搭建好php开发环境,这个就不多讲了,能找单例模式的应该有一定的php基础

在卢龙等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供做网站、网站制作 网站设计制作按需制作,公司网站建设,企业网站建设,高端网站设计,全网营销推广,外贸网站建设,卢龙网站建设费用合理。

2

新建一个database.php文件存放数据库信息

?php

$db = array(

'host'='localhost',//地址

'user'='root',//数据库用户名

'password'='root',//数据库密码

'database'='ceshi',//数据库名

)

?

3

新建Mysql.class.php编写数据库连接类操作类添加需要的属性和构造方法

构造函数加载数据库配置文件连接数据库

?php

class db {

public $conn;

public static $sql;

public static $instance=null;

private function __construct(){

require_once('database.php');

$this-conn = mysqli_connect($db['host'],$db['user'],$db['password']);

if(!mysqli_select_db($this-conn,$db['database'])){

echo "失败";

};

mysqli_query($this-conn,'set names utf8');

}

}

?这样试试吧如果你对php这类有兴趣的话,可以和我一样在后盾人经常看看教材,自己多看几遍,慢慢的以后就明白了,希望能帮到你,给个采纳吧谢谢

什么是PHP单例模式

PHP单例模式,就是一个对象只被生成一次,但该对象可以被其它众多对象使用。单例模式使用最多的场景,是数据库连接操作。我们知道,生成一个对象的操作是用new函数来实现,但是new对象都会消耗内存,而且有时候对同一个对象,在不同文件中可能会生成多次,这就造成了系统资源的浪费。然而使用单例模式,则可以很好的避免这种情况。

以数据库为例,假设我们有一个数据库的类,要实现数据库连接。如果不使用单例模式,那么在很多PHP文件中,我们可能到要创建这样的一个连接,这其实是对资源的很大浪费。那么下面介绍单例模式实现方法:

class Database

{

//定义一个属性,该属性是静态的保护或私有属性

protected static $db;

//这里构造函数一定要是私有方法

private function __construct()

{  

}

//声明一个获取类实例的方法

static function getInstace()

{  

if(self::$db) {

return self::$db;

}else {

//生成自己

self::$db = new self();

return self::$db;

}  

}

}

//错误调用方法

//用new实例化private标记构造函数的类会报错

$db = new Database();

//正确获取实例方法

$db = Database::getInstace();

使用单例模式的好处是,当你在其他地方也要使用到这个类,比如上面的数据库类。那么你可以在其它地方直接调用 Database::getInstace(),而且该实例只会被生成一次,不会被重复生成,所以不会浪费系统资源。

简单的说,单例模式生成的实例只被生成一次,而且只负责一个特定的任务。

使用单例模式有下面几个要求:

1.构造函数需要标记为private(访问控制:防止外部代码使用new操作符创建对象),单例类不能在其他类中实例化,只能被其自身实例化;

2.拥有一个保存类的实例的静态成员变量;

3.拥有一个访问这个实例的公共的静态方法(常用getInstance()方法进行实例化单例类,通过instanceof操作符可以检测到类是否已经被实例化);

4.如果严谨的话,还需要创建__clone()方法防止对象被复制(克隆)。(我上面没创建)

使用单例模式好处,总结:

1、php的应用主要在于数据库应用, 所以一个应用中会存在大量的数据库操作, 使用单例模式, 则可以避免大量的new 操作消耗的资源。

2、如果系统中需要有一个类来全局控制某些配置信息, 那么使用单例模式可以很方便的实现. 这个可以参看ZF的FrontController部分。

3、在一次页面请求中, 便于进行调试。

参考:

PHP为什么以及什么时候使用单例模式

单例模式确保某个类只有一个实例

1.只能有一个实例。

2.必须自行创建这个实例。

3.必须给其他对象提供这一实例。

那么为什么要使用PHP单例模式?

PHP一个主要应用场合就是应用程序与数据库打交道的场景,在一个应用中会存在大量的数据库操作,针对数据库句柄连接数据库的行为,使用单例模式可以避免大量的new操作。因为每一次new操作都会消耗系统和内存的资源。

优点:

1. 改进系统的设计

2. 是对全局变量的一种改进

缺点:

1. 难于调试

2. 隐藏的依赖关系

3. 无法用错误类型的数据覆写一个单例

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设计模式之单例、多例设计模式的应用分析

本篇文章是对php设计模式中的单例与多例设计模式的应用进行了详细的分析介绍 需要的朋友参考下  

单例(Singleton)模式和不常见的多例(Multiton)模式控制着应用程序中类的数量 如模式名称 单例只能实例化一次 只有一个对象 多例模式可以多次实例化 基于Singleton的特性 我们经常用Singleton配置应用程序并定义应用程序中可能随时访问的变量 但有时并不推荐使用Singleton 因为它生成了一个全局状态且 该单一根对象没有封装任何系统功能 多数情况下 会使单元测试和调试变得困难 读者根据情况自行决定 代码示例

复制代码 代码如下: ?php class SingletonExample{ private function __construct(){}//防止直接实例化 public static function getInstance(){ //不与任何对象有关联 static $instance=null; //调用此函数的所有代码共享该变量 不必要让其是类的静态变量 if($instance==null){ $instance=new SingletonExample(); } return $instance; } } $obj =SingletonExample::getInstance(); $obj =SingletonExample::getInstance(); var_dump($obj ===$obj );// true 是同一个实例 ?

Multiton与singleton相似 不同的是后者需要getInstance()函数传递关键值 对于给定的关键值只会存在唯一的对象实例 如果有多个节点 每个节点拥有唯一的表识符 且各个节点在某单次执行(如cms里的节点)可能出现多次 那么就可以用Multiton模式实现这些节点啊 Multiton节省内存 并确保同一个对象的多个实例不发生冲突 示例

复制代码 代码如下: lishixinzhi/Article/program/PHP/201311/21166

php中连接数据库,使用单例模式遇到的问题

当然是重新连接了,你是跳转不是包含。

跳转两者之间共享值要专门的传值操作,cookie\

session\

POST/GET

\静态输出


本文标题:php数据库单例 PHP常用的数据库是
本文地址:http://hbruida.cn/article/hjdpce.html