当前位置: 首页 > news >正文

php常用数据库操作

文章目录

  • PHP操作
    • 1. `mysqli_connect()` 连接数据库
    • 2. `mysqli_close()` 关闭数据库
    • 3. `mysqli_num_rows` 查询结果集中的行数
    • 4. `mysqli_select_db` 选择数据库的函数
    • 5. mysqli_query 常规的插入查找等
    • 6. header( )
    • 7.防止 sql 注入

PHP操作

1. mysqli_connect() 连接数据库

2. mysqli_close() 关闭数据库

<?php
$servername = "localhost";  // MySQL 服务器地址
$username = "root";         // 数据库用户名
$password = "password";     // 数据库密码
$dbname = "mydatabase";     // 数据库名// 建立与 MySQL 数据库服务器的连接
$conn = mysqli_connect($servername, $username, $password, $dbname);// 检查连接是否成功
if (!$conn) {die("连接失败: " . mysqli_connect_error());
}echo "连接成功!";// 在这里可以执行数据库操作// 关闭与 MySQL 数据库服务器的连接
mysqli_close($conn);
?>

mysqli_num_rows() 是 PHP 中用于获取查询结果中行数的函数,它是 MySQLi(MySQL Improved Extension)扩展库的一部分。MySQLi 是 PHP 提供的一个强大且面向对象的扩展,用于与 MySQL 数据库进行交互。

mysqli_num_rows 函数的语法如下:

mysqli_num_rows($result);

其中:

  • $result 是一个结果对象,它表示从数据库中返回的查询结果集。

3. mysqli_num_rows 查询结果集中的行数

函数返回查询结果集中的行数,即结果集中包含多少条记录。如果查询失败或返回的结果集为空,则该函数返回 0。

// 创建数据库连接
$connection = mysqli_connect('localhost', 'username', 'password', 'database');// 检查连接是否成功
if (mysqli_connect_errno()) {die('连接数据库失败: ' . mysqli_connect_error());
}// 执行查询
$query = "SELECT * FROM users";
$result = mysqli_query($connection, $query);// 获取查询结果中的行数
$num_rows = mysqli_num_rows($result);echo "查询结果中共有 {$num_rows} 条记录\n";// 关闭数据库连接
mysqli_close($connection);

4. mysqli_select_db 选择数据库的函数

是 PHP 中用于选择数据库的函数。它用于在连接到 MySQL 数据库后,选择要操作的特定数据库。

bool mysqli_select_db ( mysqli $link , string $dbname )

参数说明:

  • $link:必需,一个有效的 MySQL 连接对象。
  • $dbname:必需,要选择的数据库名称。

返回值:

  • 如果选择数据库成功,则返回 true。
  • 如果选择数据库失败,则返回 false。

5. mysqli_query 常规的插入查找等

是 PHP 中用于执行 SQL 查询的函数,它是 MySQLi(MySQL Improved Extension)扩展库的一部分。MySQLi 是 PHP 提供的一个强大且面向对象的扩展,用于与 MySQL 数据库进行交互。

mysqli_query 函数的语法如下:

mysqli_query($connection, $query);

其中:

  • $connection 是一个数据库连接对象,它表示与 MySQL 数据库建立的连接。通常通过 mysqli_connectmysqli_init 函数创建连接对象。
  • $query 是要执行的 SQL 查询语句。

mysqli_query 函数执行指定的 SQL 查询,并返回一个结果对象或布尔值,具体取决于查询的类型和执行结果。

// 创建数据库连接
$connection = mysqli_connect('localhost', 'username', 'password', 'database');// 检查连接是否成功
if (mysqli_connect_errno()) {die('连接数据库失败: ' . mysqli_connect_error());
}// 执行查询
$query = "SELECT * FROM users";
$result = mysqli_query($connection, $query);// 处理查询结果
if ($result) {// 读取结果集中的数据while ($row = mysqli_fetch_assoc($result)) {echo $row['username'] . "\n";}
} else {echo '查询失败: ' . mysqli_error($connection);
}// 关闭数据库连接
mysqli_close($connection);

6. header( )

echo '<script>window.location.href = "../index.php";</script>';
// 上面的语句可以替代下面的转向
header('Location:  ../index.php');

产生原因:由于想在进行数据库的读写之后,从 php 页面转到前端页面,使用 header() 不会执行他前面的 echo 语句,故此

7.防止 sql 注入

<?php
include_once "../variable.php";$conn = mysqli_connect($mysql_hostname, $mysql_username, $mysql_password, $mysql_database);
if(!$conn){echo "数据库".$mysql_database."连接失败";exit();
}
else echo "连接数据库".$mysql_database."成功";if(isset($_POST['text']) && isset($_POST['input'])){echo "<script>alert('提交');</script>";$cont1 = mysqli_real_escape_string($conn, $_POST['text']);$cont2 = mysqli_real_escape_string($conn, $_POST['input']);$sql = "INSERT INTO essy (column1, column2) VALUES (?, ?)";$stmt = mysqli_prepare($conn, $sql);mysqli_stmt_bind_param($stmt, "ss", $cont1, $cont2);$result = mysqli_stmt_execute($stmt);if(!$result){echo "插入数据时发生错误:" . mysqli_error($conn);}else{echo "插入数据成功";}
}
else{echo "<script>alert('提交错误');</script>";
}mysqli_close($conn);
?>

mysqli_real_escape_string():

	函数的作用就是将字符串中的特殊字符进行转义,使其成为合法的 SQL 字符串。转义后的字符串可以安全地插入到 SQL 查询语句中,而不会引发 SQL 注入问题。该函数接受两个参数:第一个是数据库连接对象,第二个是要转义的字符串。函数会返回转义后的字符串。

mysqli_prepare() :

	该函数用于准备 SQL 查询语句,返回一个 mysqli_stmt 对象。mysqli_prepare() 接受两个参数:第一个参数是数据库连接对象,第二个参数是要执行的 SQL 查询语句(参数使用占位符 "?" 表示)

这种格式可以提高执行查询的效率,并提高应用程序的安全性。

为后面的 mysqli_stmt_bind_param( ) mysqli_stmt_execute() 做准备


mysqli_stmt_bind_param( ) :

	用于绑定参数到准备好的查询语句中。它接受三个参数:第一个参数是 mysqli_stmt 对象,第二个参数是参数类型的字符串,第三个参数是要绑定的参数第二个参数类型:字符串类型:s整数类型:i双精度浮点类型:d布尔类型:b
第二个参数是根据第三个要绑定的来确定的,对应的是相应数据库中的类型,因此易知,第三个三数可以是多个值,即对应表中的不同列

只是绑定,并没有进行插入等操作,绑定之后通过 mysqli_stmt_execute() 来执行 sql 语句中的操作

具体根据 mysqli_prepare() 中的 sql 进行的


mysqli_stmt_execute()

	用于执行准备好的查询语句。它接受一个参数,即 mysqli_stmt 对象返回布尔值

以上四者搭配使用,一定程度上减小了一点点 sql 注入

相关文章:

php常用数据库操作

文章目录 PHP操作1. mysqli_connect() 连接数据库2. mysqli_close() 关闭数据库3. mysqli_num_rows 查询结果集中的行数4. mysqli_select_db 选择数据库的函数5. mysqli_query 常规的插入查找等6. header( )7.防止 sql 注入 PHP操作 1. mysqli_connect() 连接数据库 2. mysql…...

判断经纬度是否在某个城市内

一、从高德获取指定城市边界经纬度信息 通过apifox操作&#xff1a; 二、引入第三方jar包&#xff1a; maven地址&#xff1a;https://mvnrepository.com/ maven依赖&#xff1a; <dependency><groupId>org.locationtech.jts</groupId><artifactId>…...

Java——数组排序和查找

一、排序介绍 1、排序的概念 排序是将多个数据按照指定的顺序进行排列的过程。 2、排序的种类 排序可以分为两大类&#xff1a;内部排序和外部排序。 3、内部排序和外部排序 1&#xff09;内部排序 内部排序是指数据在内存中进行排序&#xff0c;适用于数据量较小的情况…...

Flutter中防抖动和节流策略

什么是防抖和节流&#xff1f; 函数节流&#xff08;throttle&#xff09;与 函数防抖&#xff08;debounce&#xff09;都是为了限制函数的执行频次&#xff0c;以优化函数触发频率过高导致的响应速度跟不上触发频率&#xff0c;出现延迟&#xff0c;假死或卡顿的现象 是应对频…...

设计模式-中介者(调停者)模式(行为型)

中介者模式 中介者模式是一种行为型模式&#xff0c;又叫调停者模式&#xff0c;它是为了解决多个对象之间&#xff0c;多个类之间通信的复杂性&#xff0c;定义一个中介者对象来封装一些列对象之间的交互&#xff0c;使各个对象之间不同持有对方的引用就可以实现交互&#xf…...

HC-05蓝牙模块配置连接和使用

文章目录 1. 前期准备 2. 进入AT模式 3. 电脑串口配置 4. 配置过程 5. 主从机蓝牙连接 6. 蓝牙模块HC-05和电脑连接 1. 前期准备 首先需要准备一个USB转TTL连接器&#xff0c;电脑安装一个串口助手&#xff0c;然后按照下面的连接方式将其相连。 VCCVCCGNDGNDRXDTXDTXD…...

云上小知识:企业选择云服务的小Tips

企业在选择云服务模式时&#xff0c;应综合考虑以下几个关键因素&#xff1a; 1. 业务需求与场景 企业需要根据自身的业务特点和需求来选择合适的云服务模式。例如&#xff0c;如果企业的用户分布广泛&#xff0c;需要跨地域提供服务&#xff0c;那么公有云可能是更好的选择。…...

生成式人工智能 - Stable Diffusion 都使用了哪些技术?

一、Stable Diffusion简述 1、简述 Stable Diffusion在2022年8月开源,是由慕尼黑大学的CompVis研究团队开发的生成式人工神经网络。该项目由初创公司StabilityAI、CompVis和Runway合作开发,并得到了EleutherAI和LAION的支持。截至2022年10月,StabilityAI已筹集了1.01亿美元…...

React的useState的基础使用

import {useState} from react // 1.调用useState添加状态变量 // count 是新增的状态变量 // setCount 修改状态变量的方法 // 2.添加点击事件回调 // userState实现计数实例import {useState} from react// 使用组件 function App() {// 1.调用useState添加状态变量// coun…...

接口自动化Requests+Pytest基础实现

目录 1. 数据库以及数据库操作1.1 概念1.2 分类1.3 作用 2 python操作数据库的相关实现2.1 背景2.2 相关实现 3. pymysql基础3.1 整个流程3.2 案例3.3 Pymysql工具类封装 4 事务4.1 案例4.2 事务概念4.3 事务特征 5. requests库5.1 概念5.2 角色定位5.3 安装5.4 校验5.5 reques…...

深入解析Kafka消息传递的可靠性保证机制

深入解析Kafka消息传递的可靠性保证机制 Kafka在设计上提供了不同层次的消息传递保证&#xff0c;包括at most once&#xff08;至多一次&#xff09;、at least once&#xff08;至少一次&#xff09;和exactly once&#xff08;精确一次&#xff09;。每种保证通过不同的机制…...

jEasyUI 设置排序

jEasyUI 设置排序 jEasyUI 是一个基于 jQuery 的框架,用于轻松构建交互式的 Web 应用程序。它提供了一系列的 UI 组件,如表格(datagrid)、树(tree)、下拉列表(combobox)等,这些组件可以帮助开发者快速实现复杂的界面功能。在本文中,我们将重点讨论如何在 jEasyUI 中…...

MySQL之查询性能优化(十二)

查询性能优化 优化COUNT()查询 4.使用近似值 有时候某些业务场景并不要求完全精确的COUNT值&#xff0c;此时可以用近似值来代替。EXPLAIN出来的优化器估算的行数就是一个不错的近似值&#xff0c;执行EXPLAIN并不需要真正地去执行查询&#xff0c;所以成本很低。很多时候&am…...

7-16 二分查找

7-16 二分查找 分数 25 全屏浏览 切换布局 作者 李廷元 单位 中国民用航空飞行学院 请实现有重复数字的有序数组的二分查找。 输出在数组中第一个大于等于查找值的位置&#xff0c;如果数组中不存在这样的数&#xff0c;则输出数组长度加一。 输入格式: 输入第一行有两个…...

对Java中二维数组的深层认识

首先&#xff0c;在JAVA中&#xff0c;二维数组是一种数组的数组。它可以看作是一个矩阵&#xff0c;通常是由于表示二维数据节后&#xff0c;如表格和网格。 1.声明和初始化二维数组 声明 int[][] arr;初始化 int[][] arrnew int[3][4];或者用花括号嵌套 int[][] arr{{1,…...

C++的STL 中 set.map multiset.multimap 学习使用详细讲解(含配套OJ题练习使用详细解答)

目录 一、set 1.set的介绍 2.set的使用 2.1 set的模板参数列表 2.2 set的构造 2.3 set的迭代器 2.4 set的容量 2.5 set的修改操作 2.6 set的使用举例 二、map 1.map的介绍 2.map的使用 2.1 map的模板参数说明 2.2 map的构造 2.3 map的迭代器 2.4 map的容量与元…...

【Java笔记】第10章:接口

前言1. 接口的概念与定义2. 接口的声明与语法3. 接口的实现4. 接口的继承5. 接口的默认方法6. 接口的静态方法7. 接口的私有方法8. 接口的作用9. 接口与抽象类的区别10. 接口在Java集合中的应用结语 上期回顾:【Java笔记】第9章&#xff1a;三个修饰符 个人主页&#xff1a;C_G…...

Angular知识概览

Angular 是一个由 Google 维护的开源前端框架&#xff0c;用于构建动态网页应用。以下是对 Angular 主要概念和特性的概览&#xff1a; 1. Angular 的核心概念 - 组件 (Component)&#xff1a;Angular 应用的基本构建块。每个组件包括一个 TypeScript 类&#xff0c;用于处理数…...

经典文献阅读之--Online Monocular Lane Mapping(使用Catmull-Rom样条曲线完成在线单目车道建图)

0. 简介 对于单目摄像头完成SLAM建图这类操作&#xff0c;对于自动驾驶行业非常重要&#xff0c;《Online Monocular Lane Mapping Using Catmull-Rom Spline》介绍了一种仅依靠单个摄像头和里程计生成基于样条的在线单目车道建图方法。我们提出的技术将车道关联过程建模为一个…...

frida timed out

从Android Q(10)开始&#xff0c;Google引入了一种新的机制&#xff0c;加快了app的启动时间 Android USAP 进程启动流程 adb shell su ps -A | grep usaproot 9917 1032 6577052 13676 __skb_wait_for_more_packets 0 S usap64 root 9928 1032 6577052…...

CANN/ops-nn RMS归一化动态量化算子

AddRmsNormDynamicQuantV2 【免费下载链接】ops-nn 本项目是CANN提供的神经网络类计算算子库&#xff0c;实现网络在NPU上加速计算。 项目地址: https://gitcode.com/cann/ops-nn 产品支持情况 产品是否支持Ascend 950PR/Ascend 950DTAtlas A3 训练系列产品/Atlas A3 推…...

从‘监控谁’到‘如何查’:手把手教你用Prometheus标签玩转K8s监控数据筛选

从‘监控谁’到‘如何查’&#xff1a;手把手教你用Prometheus标签玩转K8s监控数据筛选 在Kubernetes集群监控领域&#xff0c;数据洪流是每个运维人员必须面对的挑战。当数百个Pod不断创建销毁时&#xff0c;传统静态配置的监控方式显得力不从心。这正是Prometheus标签系统大显…...

MotuBrain:一种用于机器人控制的高级世界动作模型

26年4月来自生数公司MotuBrain团队的论文“MotuBrain: An Advanced World Action Model for Robot Control”。 Motus [5] 建立一种统一的“世界-动作”建模范式&#xff0c;将视频与动作纳入同一个生成式框架中进行建模&#xff1b;借此&#xff0c;策略建模、世界建模、视频生…...

T12 vs JBC焊台DIY终极对比:从5块钱的‘白菜白光’到千元性能,我该选哪个?

T12 vs JBC焊台DIY终极对比&#xff1a;从5块钱的‘白菜白光’到千元性能&#xff0c;我该选哪个&#xff1f; 在电子维修和DIY领域&#xff0c;一把趁手的焊台就像厨师的刀具一样重要。面对市场上琳琅满目的选择&#xff0c;T12和JBC无疑是两个最受关注的方案。前者以极低的成…...

ClawGuard Web:构建AI技能安全扫描平台,从代码安全到信任生态

1. 项目概述&#xff1a;ClawGuard Web 安全技能注册平台如果你在 OpenClaw 生态里开发或使用技能&#xff0c;那你肯定遇到过这个头疼的问题&#xff1a;从 ClawHub 或者 GitHub 上找到一个看起来不错的技能&#xff0c;但心里总犯嘀咕——这代码里会不会藏着恶意后门&#xf…...

OpenClaw Windows11 保姆级安装部署教程(专属优化、一次成功)

OpenClaw Windows11 保姆级安装部署教程&#xff08;专属优化、一次成功&#xff09;一、前言OpenClaw&#xff08;圈内俗称「小龙虾」&#xff09;是 GitHub 星标 28W 的开源本地 AI 智能体&#xff0c;主打全自动电脑操控能力&#xff0c;支持自动操作电脑、整理文件、浏览器…...

鸿蒙一气总论(六)

第六卷 本心人道心性人性一气真解卷首引天地立、万象生、文明兴、文字成&#xff0c; 天地大道在外&#xff0c;人心大道在内。天有天象&#xff0c;地有地理&#xff0c;物有物性&#xff0c; 人有人心&#xff0c;心有人性&#xff0c;神有灵机。全书十六字铁律&#xff1a; …...

ARM TPIU调试架构原理与时钟同步技术解析

1. ARM TPIU架构与调试跟踪原理在嵌入式系统开发中&#xff0c;实时跟踪调试能力是诊断复杂问题的关键。Trace Port Interface Unit (TPIU)作为ARM CoreSight调试架构的核心组件&#xff0c;承担着将芯片内部多源跟踪数据可靠传输到外部分析设备的重要职责。其设计难点在于如何…...

AI原生转型生死线(2026奇点大会闭门报告首次公开)

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;AI原生转型生死线&#xff08;2026奇点大会闭门报告首次公开&#xff09; 2026年奇点大会闭门报告显示&#xff1a;企业若未在2025年底前完成AI原生架构重构&#xff0c;其核心系统迭代效率将平均下降4…...

从绕接到焊接:硬件连接技术的演进与工程思维启示

1. 从“绕接”到“焊接”&#xff1a;一个硬件工程师的认知进化史十几年前&#xff0c;我刚踏入硬件设计这行&#xff0c;第一次在实验室的角落里看到前辈们用一把像笔一样的工具&#xff0c;将一根细细的导线在方形的金属柱上绕出紧密的螺旋。那是我与“绕接”技术的初次相遇。…...