博客列表 >5-07单利模式

5-07单利模式

冰雪琉璃
冰雪琉璃原创
2021年05月14日 20:49:37655浏览
  1. <?php
  2. //定义一个接口
  3. interface iDbBase
  4. {
  5. //数据库的操作增删查改
  6. static function insert($db,$data);
  7. static function select($db,$where[]);
  8. static function delete($db,$where[]);
  9. static function update($db, $data,$where[]);
  10. // return $this;//实现链式调用
  11. static function doConnect($dsn,$username,$password);
  12. }
  13. //抽象类使用php中的单利模式来连接数据库
  14. abstract class aDb implements iDbBase
  15. {
  16. //返回pdo的链接对象
  17. private function $instance;
  18. //private阻止此类在外部进行实例化
  19. private function __construct()
  20. {
  21. }
  22. //只能由类的自身来进行实例化
  23. static function doConnect($dsn,$username,$password){
  24. //判断$instance是否是aDb类的对象。用instanceof
  25. //self访问静态成员$instance
  26. if(!self::$instance){
  27. //实例化本类,传入连接参数。
  28. self::$instance =new PDO($dsn,$username,$password)
  29. }
  30. return self::$instance;
  31. }
  32. //self单利模式继承
  33. }
  34. //工作类
  35. class Db extends aDb
  36. {
  37. //数据库的操作增删查改
  38. static function insert($db,$data){
  39. }
  40. static function select($db,$where['gender'=>1,'userid'=>2]){
  41. //声明一个变量
  42. $str="";
  43. foreach($where as $k=>$v){
  44. if(count($where)>1){
  45. $str.=$k.'=' .$v.'and';
  46. }
  47. else{
  48. $str.=$k.'=' .$v;
  49. }
  50. }
  51. if(count($where)>1) {
  52. $str=substr($str,0,strlen(strlen)-4);
  53. }
  54. else{
  55. echo $str;
  56. }
  57. //limit限定查询表的条数
  58. return $db->query("SELECT * FROM 'myid' WHERE $str LIMIT 2")->fetchAll(PDO::FETCH_ASSOC);
  59. }
  60. static function delete($db,$where['gender'=>1,'userid'=>2]){
  61. return $db->query("SELECT * FROM 'myid' WHERE $str LIMIT 1")->fetchAll(PDO::FETCH_ASSOC);
  62. }
  63. }
  64. //客户端代码
  65. $config=[
  66. 'type'=> $type??'mysql',
  67. 'host'=> $host='host'??'localhost',
  68. 'dbname'=>$dbname='dbname'??'news',
  69. 'password'=>$password='password'??'123456tyi',
  70. 'username'=> $username='username'??'root',
  71. ];
  72. $dsn=printf('%s:host', $config['type'],$config['host'],$config['dbname']);
  73. $username=$config['username'];
  74. $password=$config['password'];
  75. //获取PDO连接对象
  76. $db=Db::doConnect($dsn,$username,$password);
  77. echo '<pre>';
  78. print_r(Db::select($db));
  79. ?>
声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议