温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

php怎么用PDO操作大数据对象

发布时间:2021-06-17 14:42:08 来源:亿速云 阅读:93 作者:小新 栏目:开发技术

这篇文章主要为大家展示了“php怎么用PDO操作大数据对象”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“php怎么用PDO操作大数据对象”这篇文章吧。

    什么是大数据对象

    “大”通常意味着“大约 4kb 或以上”,尽管某些数据库在数据达到“大”之前可以轻松地处理多达 32kb 的数据。大对象本质上可能是文本或二进制形式的,我们在 PDOStatement::bindParam() 或 PDOStatement::bindColumn() 调用中使用 PDO::PARAM_LOB 类型码可以让 PDO 使用大数据类型。PDO::PARAM_LOB 告诉 PDO 作为流来映射数据,以便能使用 PHP Streams API 来操作。

    对于 MySQL 来说,将字段类型设置为 blob 即是大对象格式的字段。而在 bindParam() 或 bindColumn() 时,指定字段的参数为 PDO::PARAM_LOB 类型,就可以直接以句柄形式获得这个对象里面的内容,就像 fopen() 一样地继续对它进行操作。

    CREATE TABLE `zy_blob` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `attach` longblob,
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin;

    这是我们测试用的一个数据表,将 attach 字段设置为了 longblob 类型,也就是比较大的 blob 类型,这样我们就可以存储更多地信息。毕竟现在的图片或文件随随便便就是轻松地几m或几十m起步的,我们直接使用最大的 blob 类型来进行简单地测试。tinyblob 的大小为 255 字节,blob 类型的大小为 65k ,mediumblob 为 16M ,longblob 为 4G 。

    直接操作大数据对象会怎么样?

    我们先来简单地直接操作大数据对象,看看是什么样的结果。

    $stmt = $pdo->prepare("insert into zy_blob (attach) values (?)");
    $fp = fopen('4960364865db53dcb33bcf.rar', 'rb');
    $stmt->execute([$fp]);
    
    $stmt = $pdo->query("select attach from zy_blob where id=1");
    $file = $stmt->fetch(PDO::FETCH_ASSOC);
    print_r($file); 
    // Array
    // (
    //     [attach] => Resource id #6
    // )

    在这段代码中,我们没有绑定字段,然后直接将 fopen() 打开的文件存储到 blob 字段中。可以看出,在数据库中,blob 相关的字段只是存储了 Resource id #6 这样的字符串。也就是说,在不做任何处理的情况下,$fp 句柄被强制转换成了字符串类型,而句柄类型被强转的结果就是只会输出一个资源ID,而 blob 也只是和字符类型的字段一样记录了这个字符串而已。

    正确的姿势

    接下来我们来看看正确的姿势,也就是通过 bindParam() 来插入数据,通过 bindColumn() 来读取数据。

    $stmt = $pdo->prepare("insert into zy_blob (attach) values (?)");
    
    $fp = fopen('4960364865db53dcb33bcf.rar', 'rb');
    
    $stmt->bindParam(1, $fp, PDO::PARAM_LOB); // 绑定参数类型为 PDO::PARAM_LOB
    $stmt->execute();
    
    $stmt = $pdo->prepare("select attach from zy_blob where id=2");
    // // $file = $stmt->fetch(PDO::FETCH_ASSOC);
    // // print_r($file); // 空的
    $stmt->execute();
    $stmt->bindColumn(1, $file, PDO::PARAM_LOB); // 绑定一列到一个 PHP 变量
    $stmt->fetch(PDO::FETCH_BOUND); // 指定获取方式,返回 TRUE 且将结果集中的列值分配给通过 PDOStatement::bindParam() 或 PDOStatement::bindColumn() 方法绑定的 PHP 变量
    print_r($file); // 二进制乱码内容
    $fp = fopen('a.rar', 'wb');
    fwrite($fp, $file);

    以上是“php怎么用PDO操作大数据对象”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI