博主信息
博文 33
粉丝 1
评论 0
访问量 28989
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
5-07单利模式
冰雪琉璃
原创
895人浏览过
  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举报处理!
全部评论 文明上网理性发言,请遵守新闻评论服务协议
0条评论
作者最新博文
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号

  • 登录PHP中文网,和优秀的人一起学习!
    全站2000+教程免费学