mysql pdo博客_7.24 PDO的使用和介绍

1,PDO的定义;php data object(php数据对象);

2,连接pdo的相关参数:$dsn、$user、$pass.

其中$dsn="mysql:host=$host;dbname=$dbname";

1)$dsn:数据源,字符串类型 2)$user=数据库连接账户名

3)$pass=数据库连接密码

3,pdo支持的数据库多达12种以上,用于连接不同的数据库;便于项目后期的扩展和数据库更改

4,PDOStatement类的作用:解析结果集,实现预处理,事务处理等特殊功能

5,PDOException类:主要用于捕获pdo异常

6,PDO类:pdo的核心,用于数据库的连接、发送sql语句等

7,关闭pdo的方法:unset($pdo)、$pdo=null;

8, PDO中的执行操作

1)增删改:int PDO::exec(string $statement)

$sql->exec($sql);

执行sql语句并返回受影响的行数

返回最后一条插入的id:$pdo->lastInsertId();

2)查询操作:用到PDOStatement PDO::query(string $statement);

如:$stmt=$pdo->query($sql);获取查询结果集

$stmt->rowCount()获取总共条数

$stmt->columnCount()获取总列数(字段)

3)pdo中的遍历操作:操作有fetch()、fetchAll()

PDO::FETCH_ASSOC 把一条记录遍历到关联数组中

PDO::FETCH_NUM 索引数组

PDO::FETCH_BOTH混合型数组

PDO::FETCH_OBJ把一条记录遍历到对象中

PDO::FETCH_BOUND(bindColumn)

9,mysql预处理:在sql语句结构和形式相同的情况下,只有参数不同所采用的一种数据处理机制,其极大的减少了带宽的浪费

1)目的:为了节约服务器带宽,避免资源的浪费

2)基本语法:

MySQL中的预处理方法:{

创建预处理语句

prepare 预处理指令 from sql语句(inser/delete/update/select)

设置参数

set @value =value

执行预处理

execute 预处理指令

如:prepare stmt1 from 'insert into user values(null,?,?,?)';

set@user_name='itcast';

set@user_password='123456';

set@user_image='default';

execute stmt1 using @user_name,@user_password,@user_image;

}

10,PDO预处理{

$sql="insert/update/delete into 表名 values(null,?,?,?)"

$stmt=$pdo->prepare($sql)

//预处理语句中如果使用?这个特殊字符的话,那么接下来的出入数组就必须要使用枚举数组

$data=array(

0=>'第一个问号的内容',

1=>'第一个问号的内容',

2=>'第一个问号的内容',

)

$stmt->execute($data)

}

11,PDO中的事务处理:要么同时成功,如果有一方失败,则数据回滚

应用场景:涉及金钱交易的时候使用

1)

MYSQL中的事务处理:如果想实现事务处理,则数据表的引擎必须是innoDB

.......

$con->autocommit(false)//关闭自动提交功能

$sql1=".....";

$sql2=".....";

$res1=$con->query($sql1);

$res2=$con->query($sql2);

if($res1&&$res2){

$con->commit();//提交事务

$conn->autocommit(true);//开启自动提交功能

}else{

$conn->rollback();//执行回滚

}

2)PDO中的事务处理:

开启事务

bool PDO::beginTransaction(void)

提交事务

bool PDO::commit(void)

回滚事务

bool PDO::rollback(void)

12,PDO中的异常捕获

基本语法:

try{

}catch(Exception $e){

echo '错误号:'.$e->getCode();

echo '错误行号:'.$e->getLine();

echo '错误文本信息:'.$e->getMessage();

}

该方法只能捕获致命错误,同时可以设置属性实现捕获逻辑异常

语法:

$pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);

PDO::ATTR_ERRMODE 错误级别

1)PDO::ERRMODE_SLIENT 常规错误,默认

1)PDO::ERRMODE_WARNING 警告错误

1)PDO::ERRMODE_EXCEPTION 异常错误

13,PDO中属性的设置和获取

1)知识点:

设置属性

bool PDO::setAttribute(int $attribute,mixed $value)

获取属性

mixed PDO::getAttribute(int $attribute)

2)常用属性

PDO::ATTR_AUTOCOMMIT:自动提交

1:自动提交

0:关闭自动提交

$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,0)//关闭自动提交

PDO::ATTR_CASE:结果集大小写

参数值:PDO::CASE_LOWER 结果集字段名称转化为大写

参数值:PDO::CASE_UPPER 结果集字段名称转化为大写

参数值:PDO::CASE_NATURAL 正常返回

$pdo->setAttribute(PDO::ATTR_CASE,PDO::CASE_LOWER)//设置结果集为小写

PDO::ATTR_PERSISTENT:长连接

注意长连接属性的设置,需要在连接数据库时设置

$data=array(PDO::ATTR_PERSISTENT=>true);

$pdo=new PDO($dsn,$user,$pass,$data);

  • 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、付费专栏及课程。

余额充值