PHP使用PDO扩展操作mysql数据库

2024-08-29 00:58

本文主要是介绍PHP使用PDO扩展操作mysql数据库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

SELECT

//查单条
function get_sub_product()
{$res_zz = $pdo->query("SELECT id FROM content WHERE is_publish = 0  LIMIT 1;");$rep = $res_zz->fetch();
}//查多条
function get_sub_product()
{$dsn = 'mysql:host=localhost;dbname=bwdb';$pdo = new PDO($dsn, 'root', 'root');$pdo->query('set names utf8');$res_zz = $pdo->query("SELECT product_id FROM sub_product WHERE 1= 1;");$rep = $res_zz->fetchAll();$product_id_arr = array();foreach ($rep as $v) {$product_id_arr[] = $v['product_id'];}return $product_id_arr;
}

INSERT

function add()
{try {$pdo->beginTransaction();$reb = $pdo->prepare("INSERT INTO `content` (`id`,`content`) VALUES(:version_id,:content);");$reb->bindParam(':version_id', $version_id, PDO::PARAM_INT);$reb->bindParam(':content', $content, PDO::PARAM_STR);$type_id = 1; $reb->bindParam(':type_id', $type_id, PDO::PARAM_INT);$reb->bindParam(':cdate', $time, PDO::PARAM_STR);$reb->bindParam(':mdate', $time, PDO::PARAM_STR);if ($reb->execute() > 0) {$pdo->commit();die("成功!");}$pdo->rollback();die("失败!");} catch (PDOException $ex) {echo($ex->getMessage());}
}function add($res_arr)
{$dsn = 'mysql:host=localhost;dbname=db';$pdo = new PDO($dsn, 'root', 'root');$pdo->query('set names utf8');$value = '';date_default_timezone_set("Asia/Shanghai"); //时区$time = date('Y-m-d h:i:s');foreach ($res_arr as $k => $v) {$hash = md5($v['ProductID'] . "-" . $v['CategoryID'] . "-" . $v['CategoryName']);$value .= "('" . $v['ProductID'] . "','" . $v['CategoryID'] . "','" . $v['CategoryName'] . "','" . $v['ProductName'] . "','" . $v['Abbreviation'] . "','" . $v['SubscribeStatus'] . "','" . $v['ProductStatus'] . "','" .$v['BrandID'] . "','" . $v['BrandName'] . "','" . $v['TradeType'] . "','" . $v['ProductModel'] . "','" . $v['UPCCode'] . "','" . $v['Weight'] . "','" . $v['Summary'] . "','" .$v['LongDescription'] . "','" . $v['BuyNotice'] . "','" . $v['PackingList'] . "','" . $v['DefaultImage'] . "','" . $v['Keywords'] . "','" . $v['VendorID'] . "','" . $v['StoreID'] . "','" .$v['CurrentPrice'] . "','" . $v['AvailableQty'] . "','" . $hash . "','" . $time . "','" . $time . "'),";}$vv = substr($value, 0, strlen($value) - 1);try {$pdo->beginTransaction();if (!empty($vv)) {$reb = $pdo->prepare("REPLACE INTO `product_list` (`product_id`, `category_id`, `category_name`, `product_name`, `abbreviation`, `subscribe_status`, `product_status`, `brand_id`, `brand_name`, `trade_type`, ". "`product_model`, `upc_code`, `weight`, `summary`, `long_description`, `buy_notice`, `packing_list`, `default_image`, `keywords`, `vendor_id`, `store_id`, `current_price`, ". "`available_qty`, `hash`, `cdate`, `mdate`) VALUES $vv;");if ($reb->execute() > 0) {$pdo->commit();return 1;}}} catch (PDOException $ex) {$pdo->rollback();}return -1;
}

UPDATE

function update()
{try {$pdo->beginTransaction();$is_publish = 1; $req = $pdo->prepare("UPDATE `content` SET is_pub=:is_pub,mdate=:mdate WHERE id = :id;");$req->bindParam(':is_publish', $is_publish, PDO::PARAM_INT);$req->bindParam(':id', $version_id, PDO::PARAM_INT);$req->bindParam(':mdate', $time, PDO::PARAM_STR);if ($req->execute()) {$pdo->commit();die("成功!");}$pdo->rollback();die("失败!");} catch (PDOException $ex) {echo($ex->getMessage());}
}

这篇关于PHP使用PDO扩展操作mysql数据库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1116383

相关文章

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

C#下Newtonsoft.Json的具体使用

《C#下Newtonsoft.Json的具体使用》Newtonsoft.Json是一个非常流行的C#JSON序列化和反序列化库,它可以方便地将C#对象转换为JSON格式,或者将JSON数据解析为C#对... 目录安装 Newtonsoft.json基本用法1. 序列化 C# 对象为 JSON2. 反序列化

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP