'
if ( self::$pdo == null )
{
$host = '115.29.223.160'
$user = 'zhangwei'
$pwd = 'zhang111'
$dbname = 'wangzhan'
$dsn = "mysql:host=$hostdbname=$dbnameport=3306"
$pdo = new PDO ( $dsn, $user, $pwd )
$pdo->query('set names utf8')
$pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false)
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION)
self::$pdo = $pdo
}
return self::$pdo
}
public static function getStmt ( $sql )
{
$pdo = self::getPdo ()
return $pdo ->prepare( $sql )
}
}
$sql = "INSERT INTO testss (wef,wef1) VALUES(?,?)"
$stmt = Db::getStmt ( $sql )
$stmt = Db::getStmt ( $sql )
?>
输出结果
NULL
object(PDO)#1 (0) { }
第一次null 第二次再获取就已经有了 不用重新连接了
单利模式好处就是保存变量 他是用static保存的 所以 退出函数 变量不会释放
关于这个问题,差不多就是这个样子的了,你如果不明白,可以自己去后盾瞅瞅,我这些都是在后盾上学的,有空可以去看一下,就算不喜欢也没关系啊,何乐而不为呢?
错。连接数据库要连接池,就是connection对象要放在一个LinkedList里面,然后每个线程一个。这个这个List被封装在一个单例模式的对象里。线程要是共享connection,要是搞起并发来,一下子就挂了。欢迎分享,转载请注明来源:内存溢出
评论列表(0条)