php objects,PDO--PHPDataObjects

PDO的环境配置:开启支持PDO 在php.ini配置文件中开启:extension=php_pdo.dllextension=php_pdo_mysql.dll在PDO操作中涉及到类:PDO、PDOStatement(预处理对象)、PDOException(异常类)一、 PDO类的构造方法:-------------------------------------------

PDO的环境配置:开启支持PDO 在php.ini配置文件中开启:

extension=php_pdo.dll

extension=php_pdo_mysql.dll

在PDO操作中涉及到类:PDO、PDOStatement(预处理对象)、PDOException(异常类)

一、 PDO类的构造方法:

---------------------------------------------------------

PDO __construct( string dsn

[, string username

[, string password

[, array driver_options]]] );

其中:dsn数据库连接信息如“mysql:host=localhost;dbname=库名”

dsn的格式:”驱动名:host=主机名;dbname=库名“

username:用户名

password:密码

driver_options:配置选项:

如: PDO::ATTR_PERSISTENT=>true,是否开启持久链接

*PDO::ATTR_ERRMODE=>错误处理模式:(可以是以下三个)(3)

PDO::ERRMODE_SILENT:不报错误(忽略)(0)

PDO::ERRMODE_WARNING:以警告的方式报错(1)

*PDO::ERRMODE_EXCEPTION:以异常的方式报错(推荐使用)。(2)

$pdo = new PDO("mysql:host=localhost;dbname=lamp36db","root","root");

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

其他方法:

--------------------------------------------------------

1. query($sql); 用于执行查询SQL语句。返回PDOStatement对象

2. exec($sql); 用于执行增、删、改操作,返回影响行数;

3. getAttribute(); 获取一个"数据库连接对象"属性。

4. setAttribute(); 设置一个"数据库连接对象"属性。

5. beginTransaction 开启一个事物(做一个回滚点)

6. commit提交事务

7. rollBack事务回滚操作。

8. errorCode获取错误码

9. errorInfo获取错误信息

10.lastInsertId 获取刚刚添加的主键值。

11.prepare创建SQL的预处理,返回PDOStatement对象

12.quote为sql字串添加单引号。

预处理对象PDOStatement对象:

=============================================

我们可以通过PDO的方法来获取PDOStatement:

1.PDO的query(查询sql)方法获取,用于解析结果集

2.PDO的prepare(SQL)方法获取,用于处理参数式sql并执行操作。

PDOstatement对象的方法:

----------------------------------------------------------------

1、fetch() 返回结果集的下一行,结果指针下移,到头返回false 。

参数: PDO::FETCH_BOTH (default)、:索引加关联数组模式

PDO::FETCH_ASSOC、 :关联数组模式

PDO::FETCH_NUM、 :索引数组模式

PDO::FETCH_OBJ、 :对象模式

PDO::FETCH_LAZY :所有模式(SQL语句和对象)

2、fetchAll() 通过一次调用返回所有结果,结果是以数组形式保存

参数:PDO::FETCH_BOTH (default)、

PDO::FETCH_ASSOC、

PDO::FETCH_NUM、

PDO::FETCH_OBJ、

PDO::FETCH_COLUMN表示取指定某一列,

如:$rslist = $stmt->fetchAll(PDO::FETCH_COLUMN,2);取第三列

3、execute() 负责执行一个准备好了的预处理语句

4. fetchColumn()返回结果集中下一行某个列的值

5. setFetchMode()设置需要结果集合的类型

6. rowCount() 返回使用增、删、改、查操作语句后受影响的行总数

7. setAttribute()为一个预处理语句设置属性

8. getAttribute()获取一个声明的属性

9. errorCode() 获取错误码

10. errorInfo() 获取错误信息

11. bindParam() 将参数绑定到相应的查询占位符上

bool PDOStatement::bindParam ( mixed $parameter , mixed &$variable [, int $data_type [, int $length [, mixed $driver_options ]]] ) 其中: $parameter:占位符名或索引偏移量 &$variable:参数的值,需要按引用传递也就是必须放一个变量

其中参数:$data_type:数据类型PDO::PARAM_BOOL/PDO::PARAM_NULL/PDO::PARAM_INT/PDO::PARAM_STR/

PDO::PARAM_LOB/PDO::PARAM_STMT/PDO::PARAM_INPUT_OUTPUT

$length:指数据类型的长度 $driver_options:驱动选项。

12. bindColumn() 用来匹配列名和一个指定的变量名,这样每次获取各行记录时,会自动将相应的值赋给变量。

13. bindValue() 将一值绑定到对应的一个参数中

14. nextRowset() 检查下一行集

15. columnCount() 在结果集中返回列的数目

16. getColumnMeta() 在结果集中返回某一列的属性信息

17. closeCursor() 关闭游标,使该声明再次执行

在PDO中参数式的SQL语句有两种(预处理sql):

1.insert into stu(id,name) value(?,?);//?号式(适合参数少的)

2.insert into stu(id,name) value(:id,:name);// 别名式(适合参数多的)

在PDO中为参数式SQL语句赋值有三种:

1.使用数组

$stmt->execute(array("lamp1404","qq2"));

$stmt->execute(array("id"=>"lamp1404","name"=>"qq2"));

2.使用方法单个赋值

$stmt->bindValue(1,"lamp1901");

$stmt->bindValue(2,"qq2");

$stmt->execute();

$stmt->bindValue(":id","lamp1901",PDO::PARAM_STR); //带指定类型

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

$stmt->execute();

3. 使用方法绑定变量

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

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

$id="lamp1401";

$name="qq2";

$stmt->execute();

事务处理

-----------------------------------------------

事务:将多条sql操作(增删改)作为一个操作单元,要么都成功,要么都失败。(如果一次插入多条数据,一条执行失败,数据回滚,全部删除)-----

4. PDO对事务的支持

第一:被操作的表必须是innoDB类型的表(支持事务)

MySQL常用的表类型:MyISAM(非事务)增删改速度快、InnodB(事务型)安全性高

//更改表的类型为innoDB类型

mysql> alter table stu engine=innodb;

Query OK, 29 rows affected (0.34 sec)

Records: 29 Duplicates: 0 Warnings: 0

//查看表结构

mysql> show create table stu\G;

第二:使用PDO就可以操作数据库了

使用到了PDO中的方法:

beginTransaction 开启一个事物(做一个回滚点)

commit提交事务

rollBack事务回滚操作。

使用情况:当做多条sql语句处理时(增删改),要求是都必须成功。

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 宝塔是一款流行的服务器管理面板软件,可以方便地用于管理服务器和网站。ODBC是一种标准的数据库访问接口,可以使不同的编程语言通过统一的方式来访问数据库。PDO-SQLSRV是一种PHP的扩展模块,用于连接和操作Microsoft SQL Server数据库。PHP5.6是PHP的一个版本,支持各种功能和特性。 在使用宝塔搭建网站时,可以使用ODBC与数据库进行连接和操作。使用PDO-SQLSRV扩展模块可以方便地在PHP中使用Microsoft SQL Server数据库。PHP5.6版本可以兼容这些扩展和模块,并提供了许多其他的功能和语法特性。 首先,需要在宝塔中安装ODBC和PDO-SQLSRV扩展模块。可以通过宝塔的软件管理功能来安装和配置这些扩展模块。安装完成后,可以在PHP配置文件中启用这些扩展模块。 然后,可以在PHP脚本中使用ODBC和PDO-SQLSRV来连接和操作数据库。可以使用ODBC连接字符串来连接数据库,并使用PDO-SQLSRV提供的方法来执行SQL查询和操作。 例如,可以使用以下代码示例连接到数据库并执行查询: ```php <?php $serverName = "your_server_name"; $connectionOptions = array( "Database" => "your_database_name", "Uid" => "your_username", "PWD" => "your_password" ); // Connect to SQL Server $conn = odbc_connect("Driver={ODBC Driver 17 for SQL Server};Server=$serverName;", $connectionOptions); if ($conn) { // Execute SQL query $query = "SELECT * FROM your_table"; $result = odbc_exec($conn, $query); // Fetch and display results while ($row = odbc_fetch_array($result)) { echo $row['column1'] . " " . $row['column2'] . "<br/>"; } // Close the connection odbc_close($conn); } else { echo "Failed to connect to database"; } ?> ``` 以上是关于宝塔、ODBC、PDO-SQLSRV和PHP5.6的简要介绍和使用示例。希望对您有所帮助! ### 回答2: 宝塔面板是一款流行的服务器管理面板,可以方便地进行服务器配置和管理。而ODBC是一种开放数据库连接标准,可以实现不同数据库之间的连接和交互。PDO-SQLSRV是PHP的一个扩展,用于连接和操作Microsoft SQL Server数据库。 在宝塔面板中安装ODBC和PDO-SQLSRV扩展可以使PHP能够通过ODBC连接到Microsoft SQL Server数据库。而PHP5.6是一种较为古老的PHP版本,但仍然被一些项目所使用。 安装ODBC和PDO-SQLSRV扩展需要一些步骤。首先,在宝塔面板的软件商店中找到ODBC扩展和PDO-SQLSRV扩展,并进行安装。然后,通过SSH登录到服务器,编辑php.ini文件,在extension部分添加odbc和pdo_sqlsrv的扩展引用,保存文件并重启服务器。 安装完成后,可以使用PDO-SQLSRV扩展提供的方法在PHP代码中连接到Microsoft SQL Server数据库,并执行各种数据库操作,如查询数据、插入数据、更新数据等。具体代码可以参考PDO-SQLSRV的文档和教程。 总之,通过在宝塔面板中安装ODBC和PDO-SQLSRV扩展,并配置php.ini文件,可以实现在PHP5.6中连接和操作Microsoft SQL Server数据库。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值