博客列表 >0619作业2019年06月20日12:04:17

0619作业2019年06月20日12:04:17

Viggo的博客
Viggo的博客原创
2019年06月20日 12:07:331089浏览

利用命名空间声明接口,然后利用基础类继承接口,实现PDO的连接与查询操作。

实例

<?php

namespace Test;
use PDO;

if (!interface_exists(__NAMESPACE__.'\iDbParam')) //判断命名空间是否存在不存在返回true 不存在才需要声明所以加!取反
{
    interface iDbParam
    {
        const TYPE = 'mysql';
        const HOST = 'localhost';
        const USER_NAME = 'root';
        const PASSWORD = 'root';
        const DBNAME = 'php';
        public static function connection();
    }
}

//基本类继承接口用到命名空间继承
class Connection implements namespace\iDbParam
{
//    初始化连接参数 值时引用的命名空间接口内的属性
    private static $type = iDbParam::TYPE;
    private static $host = iDbParam::HOST;
    private static $userName = iDbParam::USER_NAME;
    private static $password = iDbParam::PASSWORD;
    private static $dbName = iDbParam::DBNAME;
    private static $pdo = null;

//    连接数据库
    public static function Connection()
    {
        // TODO: Implement connection() method.

        $dsn = self::TYPE.':host='.self::HOST.';dbname='.self::DBNAME;
        $user = self::USER_NAME;
        $password = self::PASSWORD;
        $pd = new PDO($dsn,$user,$password);
        self::$pdo = $pd;
        return $pd;//这里返回时方便外部自己写操作代码
    }

//    查询代码
    public static function select($table,$field='',$where='',$limit=0,$offset=0)
    {
        $field = empty($field) ? '*' : $field;
        $where = empty($where) ? '' : ' WHERE ' .$where;
        $limit = empty($limit) ? '' : ' LIMIT ' .$limit;
        $offset = empty($offset) ? '' : ' OFFSET '.$offset;


        $sql = 'select '.$field.' from '.$table.$where.$limit.$offset;
        $stmt = self::$pdo->prepare($sql);
        $stmt->execute();
        $stmt->debugDumpParams();die;
        return $stmt->fetchall(PDO::FETCH_ASSOC);

    }

}

//以后连接数据库只需要这个静态方法即可,注意命名空间
$link = Connection::Connection();

//执行一个查询
//$stmt = $link->prepare('select * from movies limit 5');
//$stmt->execute();
////$stmt->debugDumpParams();die;
//echo '<pre>'.print_r($stmt->fetchAll(PDO::FETCH_ASSOC),true);

//调用select()
echo '<pre>'.print_r(Connection::select('movies','name,image','name=\'情书\'',5),true);

运行实例 »

点击 "运行实例" 按钮查看在线实例


声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议