Java 单例模式数据库连接

Java 单例模式数据库连接,第1张

我认为单例模式是为了减少不必要的内存开销,只让内存有一个类的内存空间。而你说的这个应该要用数据库连接池,连接仍然要释放,只不过这里个释放是释放连接池里的资源,而非释放连接,连接池的连接任然没变

PHP pdo单例模式连接数据库

'

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,要是搞起并发来,一下子就挂了。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9988379.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存