php查询结果集pdo,php学习笔记(二十三)PDO的预处理语句的查询以及结果集的使用...

/**

* php data object

*

* 预处理(推荐使用)

*

* PDOStatement

* 可以准备一个预处理语句,也可以处理结果集

* 占位符有两种:

* ?参数索引数组,按索引顺序使用

* 名字参数关联数组,按名次使用,与顺序无关

*

*/

//一:链接

$dsn = "mysql:host=localhost;dbname=hibernate";

$username = "root";

$passwd = "root";

$options = array(PDO::ATTR_AUTOCOMMIT=>1);

try {

$pdo = new PDO($dsn, $username, $passwd, $options);

}catch (PDOException $e){

echo "数据库连接失败".$e->getMessage();

exit;

}

//二:预处理

//准备语句

//$sql = "select * from users where id = ?";

$sql = "select * from users where id = :id";

$stmt = $pdo->prepare($sql);//所有sql都可以执行

//绑定

//$stmt->bindParam(1, $id);

$stmt->bindParam(":id", $id);

$id = 2;

if ($stmt->execute()) {

echo "执行成功"."
";

echo "最后影响的插入id".$pdo->lastInsertId()."
";

}

//直接在执行的时候插入语句(可用于传值接收)

$sql = "select * from users where id = :id";

$stmt = $pdo->prepare($sql);//所有sql都可以执行

$stmt->execute(array(":id"=>2));

//直接在执行的时候插入语句(可用于传值接收)

$sql = "select * from users where id = ?";

$stmt = $pdo->prepare($sql);//所有sql都可以执行

$stmt->execute(array(12));

//获取结果集

$sql = "select * from users where id < ?";

$stmt = $pdo->prepare($sql);//所有sql都可以执行

$stmt->execute(array(12));

//设置模式的话,就是索引获取都按照这个模式了

$stmt->setFetchMode(PDO::FETCH_NUM);

/**

* 方式一:单行获取

*/

//索引数组返回

//$row = $stmt->fetch(PDO::FETCH_NUM);

//关联数组返回

//$row = $stmt->fetch(PDO::FETCH_ASSOC);

//都返回返回

//$row = $stmt->fetch(PDO::FETCH_BOTH);

//然后再进行获取

//$row = $stmt->fetch();

//print_r($row);

/**

* 方式二:全部获取

*/

$data = $stmt->fetchAll();

/**

* 方式三:绑定列

* 下载执行方法之前

* 执行 时候后,循环输出时,进行赋值

*/

$sql = "select * from users where id < :id";

$stmt = $pdo->prepare($sql);//所有sql都可以执行

$stmt->bindColumn("id", $id,PDO::PARAM_INT);

$stmt->bindColumn("name", $name,PDO::PARAM_STR);

$stmt->bindColumn("price", $price);

$stmt->execute(array(":id"=>5));

//输出列名

for ($i = 0; $i < $stmt->columnCount(); $i++) {

$field = $stmt->getColumnMeta($i);

echo $field["name"]."---";

}

echo "
";

//输出所有查询数据

while ($stmt->fetch()){

echo "$id--$name--$price
";

}

echo "总行数:".$stmt->rowCount()."
";

echo "总列数:".$stmt->columnCount()."
";

?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: `pdo_mysql.default_socket` 是 PHP 的配置选项之一,它用于指定 MySQL 数据库服务器的 Unix 套接字文件路径。当使用 PDO 连接 MySQL 数据库时,如果没有手动指定连接参数的 Unix 套接字路径,那么 PDO 将会使用 `pdo_mysql.default_socket` 指定的路径作为默认值。 如果你的 MySQL 数据库服务器安装在默认的位置,并且 PHP 和 MySQL 安装在同一台服务器上,你可以将 `pdo_mysql.default_socket` 设置为 `/var/run/mysqld/mysqld.sock`,这是许多 Linux 系统上 MySQL 默认的 Unix 套接字路径。如果你的 MySQL 数据库服务器安装在不同的位置,你需要根据实际情况修改 `pdo_mysql.default_socket` 的值。 你可以通过修改 `php.ini` 文件来设置 `pdo_mysql.default_socket`。在 `php.ini` 文件中搜索 `pdo_mysql.default_socket`,并将其设置为你需要的 Unix 套接字路径。如果你不知道 Unix 套接字文件的路径,可以通过运行 `mysql_config --socket` 命令来获取。 ### 回答2: php.ini是PHP的配置文件之一,它用于配置PHP的运行参数和选项。而pdo_mysql.default_socket是php.ini中的一个设置,用于指定PDO使用的MySQL套接字文件的路径。 MySQL套接字文件是MySQL数据库连接的一种方式,通过套接字文件,PHP可以与MySQL进行通信和交互。这个设置允许我们指定套接字文件的路径,以便PHP可以正确地连接到MySQL数据库。 在php.ini文件中,当pdo_mysql.default_socket没有设置时,PHP会尝试使用默认的套接字文件路径。这个默认的路径通常是由MySQL服务器的安装位置确定的。然而,如果MySQL服务器的安装位置不同,或者我们希望使用不同的套接字文件,就需要通过修改php.ini文件来指定pdo_mysql.default_socket的值。 例如,如果我们的MySQL服务器安装在/usr/local/mysql目录下,而默认的套接字文件路径是/tmp/mysql.sock,我们可以通过修改php.ini中的pdo_mysql.default_socket参数来指定新的套接字文件路径,如下所示: pdo_mysql.default_socket = /usr/local/mysql/mysql.sock 这样一来,PHP在连接MySQL数据库时就会使用我们指定的套接字文件路径。 总之,pdo_mysql.default_socket是php.ini中用于指定PDO使用的MySQL套接字文件路径的设置。根据实际需要,我们可以通过修改php.ini文件来设置该值,以确保PHP能够正确地连接到MySQL数据库。 ### 回答3: php.ini是PHP的配置文件,用于配置PHP运行环境的各种参数和选项。其中的pdo_mysql.default_socket是一个用于指定PDO连接MySQL数据库所使用的Unix套接字文件路径的选项。 由于PHP在连接MySQL数据库时,默认使用的是MySQL的TCP/IP协议进行通信,所以pdo_mysql.default_socket选项默认为空。这种情况下,PHP通过TCP/IP连接MySQL数据库,在连接字符串中指定MySQL服务器的IP地址和端口号。 如果想要使用Unix套接字文件进行连接,可以通过修改php.ini文件中pdo_mysql.default_socket的值来实现。例如,可以将pdo_mysql.default_socket的值设置为"/tmp/mysql.sock",表示连接MySQL数据库的时候使用套接字文件"/tmp/mysql.sock"。 使用Unix套接字文件连接MySQL数据库相对于TCP/IP连接有一些优势,如更快的速度、更高的安全性和更少的资源占用。因此,在某些情况下,使用Unix套接字文件连接MySQL数据库可能会更加适用。 需要注意的是,修改php.ini文件后,需要重启Web服务器或者PHP-FPM才能使修改生效。此外,还可以在代码中使用ini_set()函数来修改pdo_mysql.default_socket的值,在连接MySQL数据库之前进行动态配置。 综上所述,pdo_mysql.default_socket是用于指定PDO连接MySQL数据库所使用的Unix套接字文件路径的选项,在需要使用Unix套接字文件进行连接时,可以通过修改php.ini文件中的该选项的值来实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值