• PHP知识点笔记


    显示错误:PDOException could not find driver.

    是表示PDO没有安装对应数据库的扩展,比如没有安装PDO_mysql

    http://pecl.php.net/package/PDO_MYSQL

    下载源码

    phpize

    ./configure --with-php-config=/usr/local/php/bin/php-config
    ./make

    ./make install 

    phpExcel的使用需要使用到php的xmlreader和xmlwriter扩展

    如果你是使用yum安装php

    就直接使用yum install php-xml来进行安装

    php的define不能重复定义

    比如:

    <?php
    
    define("TEST", "11");
    
    define("TEST", "22");
    
    echo TEST;
     
    [yejianfeng@xen193v ~/handcode]$ php test.php 
    
    PHP Notice:  Constant TEST already defined in /home/yejianfeng/handcode/test.php on line 4
    
    Notice: Constant TEST already defined in /home/yejianfeng/handcode/test.php on line 4
    
    11
    

    PHP如何获取本地所有变量

    $localVariables = compact(array_keys(get_defined_vars()));

    安装php模块可以这么安装

    PHP_PDO_SHARED=1 pecl install pdo_mysql

    mysql的字符编码

    mysql一般默认的客户端字符编码为:latin1

    mysql的字符编码有几种:

    mysql> show variables like "character_set_%";
    +--------------------------+----------------------------+
    | Variable_name            | Value                      |
    +--------------------------+----------------------------+
    | character_set_client     | utf8                       |
    | character_set_connection | utf8                       |
    | character_set_database   | latin1                     |
    | character_set_filesystem | binary                     |
    | character_set_results    | utf8                       |
    | character_set_server     | latin1                     |
    | character_set_system     | utf8                       |
    | character_sets_dir       | /usr/share/mysql/charsets/ |
    +--------------------------+----------------------------+

    其中信息输入路径是

    client - connection - server

    信息输出路径是

    server - connection - result

    输入set names utf8是临时设置client和connection的字符编码

    如何在PHP中初始化mysql的字符编码?

    有两种方法可以初始化设置:

    1

            $pdo = new PDO("mysql:host={$config['host']};dbname={$config['dbname']};port={$config['port']}", 
    
                $config['user'], $config['password'], array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8"));

    2

       $pdo = new PDO("mysql:host={$config['host']};dbname={$config['dbname']};port={$config['port']}", 
    
                $config['user'], $config['password']);
    
            $pdo->exec('set names utf8');

    PHP的PDO扩展

    a109e3e25047944f4114503e2d273599

    使用php如果要使用PDO,你需要安装的扩展除了PDO,还要各种数据库的驱动,PDO扩展是定义了一系列接口,但是你不可以使用PDO扩展直接操作数据库,需要安装制定PDO驱动扩展

    PDO扩展的说明:http://www.php.net/manual/en/intro.pdo.php

    PDO扩展只能在PHP 5.0之上使用(使用了php的OO属性)

    针对不同的数据库的扩展有:

    1271fe0e34c447d27b6e9ca76a894420

    为什么PDO的prepare不能打出最后的sql

    使用PDO一直有一个郁闷的地方,就是使用prepare的时候想要将最后执行的sql打出来做log,发现没有方法。。。

    后来想了想,prepare是mysql的语句,那么PDO的prepare和execute实际上是对mysql发送了几次请求,prepare,set,execute

    mysql> PREPARE stmt1 FROM 'SELECT SQRT(POW(?,2) + POW(?,2)) AS hypotenuse';
    mysql> SET @a = 3;
    mysql> SET @b = 4;
    mysql> EXECUTE stmt1 USING @a, @b;
    +------------+
    | hypotenuse |
    +------------+
    |          5 |
    +------------+
    mysql> DEALLOCATE PREPARE stmt1;

    所以,如果要打出log,只有自己拼sql了。。。

    实时了解作者更多技术文章,技术心得,请关注微信公众号“轩脉刃的刀光剑影”

    本文基于署名-非商业性使用 3.0许可协议发布,欢迎转载,演绎,但是必须保留本文的署名叶剑峰(包含链接http://www.cnblogs.com/yjf512/),且不得用于商业目的。如您有任何疑问或者授权方面的协商,请与我联系

  • 相关阅读:
    JVM运行参数优化详细教程
    idea 代码热启动配置方法
    Spring MVC拦截器完整代码示例
    Spring MVC异常处理代码完整实例
    Python3基础语法(20190617)
    Java代码生成器Easy Code
    Mybatis @Many注解一对多关联映射
    Mybatis @One注解使用
    Mybatis @ResultMap复用@Result
    Mybatis @Result注解的使用案例
  • 原文地址:https://www.cnblogs.com/yjf512/p/3070760.html
Copyright © 2020-2023  润新知