微赞php.ini_微赞微擎二开笔记开发手册之数据库操作函数(十二)

本文详细介绍了微赞框架中的数据库操作函数,包括pdo_debug、pdo_delete、pdo_fetch、pdo_fetchall等,涵盖错误信息获取、记录删除、数据查询等功能,提供了丰富的使用示例。
摘要由CSDN通过智能技术生成

系统数据库操作函数全部位于 framework/function/db.func.php 文件内。

注意:系统会默认加载该文件,因此该文件内所有函数均可直接使用。

1.pdo_debug

array pdo_debug([boolean $output], [array $append]);

获取pdo操作错误信息列表

$output boolean 是否要输出执行记录和执行错误信息

$append array 加入执行信息,如果此参数不为空则 $output 参数为 false

获取pdo操作错误信息列表,返回由 SQL 语句、参数列表、错误代码组成的数组。

$sql = ‘SELECT * FROM ‘ . tablename(‘account’) . ‘ WHERE `acid` = :acid’; $params = array(‘:uniacid’ ⇒ 123, array(100)); $account = pdo_fetch($sql, $params); pdo_debug(true);

…… Array (

[sql] => SELECT * FROM `ims_account` WHERE `acid` = :acid

[params] => Array

(

[:uniacid] => 123

[0] => Array

(

[0] => 100

)

)

[error] => Array

(

[0] => HY093

[1] =>

[2] =>

)

)

……

2.pdo_delete

mixed pdo_delete(string $table, array $params, string $glue);

删除记录

$table string 数据表名

$params array 参数列表

$glue string 条件类型 可以为AND OR

删除记录,如果删除成功返回影响行数,失败返回 false。

pdo_delete(‘account’, array(‘uniacid’ ⇒ ‘200’));

3.pdo_fetch

mixed pdo_fetch(string $sql, [array $params]);

执行SQL返回第一行

$sql string 需要执行的SQL语句

$params array 参数列表

执行SQL返回第一行, 如果参数列表错误,返回 false,否则返回 SQL 结果。

$sql = ‘SELECT * FROM ‘ . tablename(‘account’) . ‘ WHERE `acid` = :acid’; $params = array(‘:acid’ ⇒ ‘111’); $account = pdo_fetch($sql, $params); print_r($account);

Array (

[acid] => 111

[uniacid] => 181

[hash] => YNG66gt4

[type] => 1

[isconnect] => 1

)

pdo_fetchall mixed pdo_fetchall(string $sql, [array $params], [string $keyfield]);

执行SQL返回全部记录

$sql string 需要执行的SQL语句

$params array 参数列表

$keyfield string 将该字段的值作为结果索引

执行SQL返回全部记录, 如果参数列表错误,返回 false。如果可选参数 $keyfield 不为空,则将该字段的值作为结果数组索引。

$sql = ‘SELECT * FROM ‘ . tablename(‘account’) . ‘ WHERE `acid` > :acid’; $params = array(‘:acid’ ⇒ ‘400’); $accounts = pdo_fetchall($sql, $params); print_r($accounts);

Array (

[0] => Array

(

[acid] => 434

[uniacid] => 288

[hash] => M3BaP3WR

[type] => 1

[isconnect] => 0

)

[1] => Array

(

[acid] => 433

[uniacid] => 288

[hash] => I01dujgC

[type] => 1

[isconnect] => 0

)

[2] => Array

(

[acid] => 440

[uniacid] => 444

[hash] => E33pwA88

[type] => 1

[isconnect] => 1

)

)

4.pdo_fetchallfields

array pdo_fetchallfields(string $tablename);

获取所有字段名称

$tablename string 数据表名

获取所有字段名称

$fields = pdo_fetchallfields(tablename(‘account’)); print_r($fields); Array ( [0] ⇒ acid

[1] => uniacid

[2] => hash

[3] => type

[4] => isconnect

)

5.pdo_fetchcolumn

mixed pdo_fetchcolumn(string $sql, [array $params], [int $column]);

执行SQL返回第一个字段

$sql string 需要执行的SQL语句

$params array 参数列表

$column int 返回查询结果的某列,默认为第一列

执行SQL语句,返回一列数据,默认为第一列。

$sql = ‘SELECT COUNT(*) FROM ‘ . tablename(‘account’); $total = pdo_fetchcolumn($sql);

echo $total; 1000 ===== pdo_fieldexists ===== boolean pdo_fieldexists(string $tablename, [string $filedname]); 查询字段是否存在 ||参数 $tablename string 查询表名 $fieldname string 查询字段名 ||返回值 查询字段是否存在于指定数据表中 ||示例 $exists = pdo_fieldexists(‘account’, ‘acid2’); echo $exists; false

6.pdo_indexexists

boolean pdo_indexexists(string $tablename, [string $indexname]);

查询索引是否存在

$tablename string 查询表名

$indexname string 查询字段名

查询索引是否存在于指定数据表中

$exists = pdo_indexexists(‘account’, ‘acid2’); echo $exists; false ===== pdo_insert ===== mixed pdo_insert(string $table, [array $data], [boolean $replace]); 添加或更新纪录 ||参数 $table string 数据表名 $data array 插入数据 $replace boolean 是否执行REPLACE INTO ||返回值 添加或更新纪录,如果添加成功返回 true,否则返回 false。如果可选参数 $replace 为 true,则执行REPLACE INTO,如果更新成功,返回影响行数,否则插入一条新数据。 ||示例 $account = pdo_insert(‘account’, array(‘uniacid’ ⇒ 200)); echo $account; true pdo_insertid int pdo_insertid();

获取上一步 INSERT 操作产生的 ID

获取上一步 INSERT 操作产生的 ID,如果失败或没有 Insert 操作,则返回 false。

pdo_insert(‘account’, array(‘uniacid’ ⇒ 200)); $newId = pdo_insertid(); echo $newId;

7.pdo_query

boolean int pdo_query(string $sql, [array $params]);

执行一条非查询语句

$sql string 需要执行的SQL语句

$params array 参数列表

执行一条非查询语句,成功返回受影响的行数,失败返回FALSE。

创建一个数据表 $sql = ‘CREATE TABLE `ims_account` ( `acid` int(10) unsigned NOT NULL AUTO_INCREMENT, `uniacid` int(10) unsigned NOT NULL, `hash` varchar(8) NOT NULL, `type` tinyint(3) unsigned NOT NULL DEFAULT ‘1’ COMMENT ‘1为微信,2为易信’, `isconnect` tinyint(1) NOT NULL DEFAULT ‘0’, PRIMARY KEY (`acid`), KEY `idx_uniacid` (`uniacid`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8′; pdo_query($sql); pdo_run void pdo_run(string $sql); ||参数 $sql string 需要执行的SQL语句 ||返回值 ^void ||示例 创建两个数据表

$sql = ‘CREATE TABLE `ims_account` ( `acid` int(10) unsigned NOT NULL AUTO_INCREMENT, `uniacid` int(10) unsigned NOT NULL, `hash` varchar(8) NOT NULL, `type` tinyint(3) unsigned NOT NULL DEFAULT ‘1’ COMMENT ‘1为微信,2为易信’, `isconnect` tinyint(1) NOT NULL DEFAULT ‘0’, PRIMARY KEY (`acid`), KEY `idx_uniacid` (`uniacid`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8; ‘CREATE TABLE `ims_account` ( `acid` int(10) unsigned NOT NULL AUTO_INCREMENT, `uniacid` int(10) unsigned NOT NULL, `hash` varchar(8) NOT NULL, `type` tinyint(3) unsigned NOT NULL DEFAULT ‘1’ COMMENT ‘1为微信,2为易信’, `isconnect` tinyint(1) NOT NULL DEFAULT ‘0’, PRIMARY KEY (`acid`), KEY `idx_uniacid` (`uniacid`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8;’;

pdo_run($sql);

8.pdo_tableexists

boolean pdo_tableexists(string $tablename);

检测数据表是否存在

$tablename string 数据表名

检测数据表是否存在,如果存在返回 true, 否则返回 false。

$exists = pdo_tableexists(‘account’); print_r($exists); true ===== pdo_update ===== mixed pdo_update(string $table, [array $data], [array $params], [string $glue]); ||更新记录 ||参数 $table string 数据表名 $data array 更新记录 $params array 更新参数 $glue string 条件类型 可以为AND OR ||返回值 更新数据表记录,如果更新成功,返回影响行数,否则返回 fasle。 ||示例 pdo_update(‘account’, array(‘uniacid’ ⇒ ‘100’), array(‘acid’ ⇒ ’10’));

开心洋葱 , 版权所有丨如未注明 , 均为原创丨未经授权请勿修改 , 转载请注明微赞微擎二开笔记开发手册之数据库操作函数(十二)!

  • 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.iniPHP的配置文件之一,它用于配置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.iniPHP的配置文件,用于配置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、付费专栏及课程。

余额充值