【php】php操作MySQL数据库
一、操作步骤:
1. 连接MySQL数据库并判断是否连接成功
2. 选择数据库
3. 设置字符集
4. 准备SQL语句
5. 向MySQL服务发送SQL语句
6. 解析处理结果集
7. 释放结果集,关闭数据库连接
二、常用操作:
1. mysqli_connect();--连接数据库,并返回一个连接资源
格式: mysql_connect(主机名,用户,密码);
--其中参数可选,若不写则参考php.ini中默认配置
2. mysqli_error(); --获取刚刚(最后)执行数据库操作的错误信息
3. mysqli_errno(); --获取刚刚(最后)执行数据库操作的错误号
错误号为0表示没有错误
4. mysqli_select_db(数据库名[,数据库连接]);
选择一个数据库,等同于"use 库名"语句
5. mysqli_set_charset(字符编码); --设置字符编码
例如:mysql_set_charset("utf8"); 等同于:mysql_query("set names utf8");
6. mysqli_query(sql语句[,数据库连接]); -- 发送一条sql语句
sql语句若是查询,则返回结果集,其他则返回boolean值表示执行是否成功。
7. 解析结果集函数:
mysqli_fetch_array(); --以关联和索引两种方式数组解析结果集
也可以指定第二参数来定义返回格式:
MYSQL_BOTH(0关联和索引)/MYSQL_NUM(2索引)/MYSQL_ASSOC(1关联)
mysqli_fetch_row(); --以索引式数组解析结果集
*mysqli_fetch_assoc(); --以关联式数组解析结果集
mysqli_fetch_object(); --以对象方式解析结果集
8. mysqli_free_result(结果集名); --释放结果集
9. mysqli_close(数据库连接); --关闭数据库连接
10. mysqli_num_rows(结果集); --获取结果集中的数据条数
11. mysqli_num_fields(结果集); --获取结果集中的列数(字段数量)
12. mysqli_result(); --定位取结果
echo mysql_result($result,0,3)."<br/>"; //获取第1条数据的第4列中的值
echo mysql_result($result,1,2)."<br/>"; //获取第2条数据的第3列中的值
echo mysql_result($result,5,4)."<br/>"; //获取第6条数据的第5列中的值
13.mysqli_affected_rows — 取得前一次 MySQL 操作所影响的记录行数
关联的 INSERT,UPDATE 或 DELETE 查询所影响的记录行数。
14. mysqli_insert_id — 取得上一步 INSERT 操作产生的 ID
//在php当中操作mysql数据库的六脉神剑 //1.连接数据库服务器,并判断是否成功 mysqli_connect(服务器地址,用户名,密码[,数据库名]);
$link = mysqli_connect('localhost','root',''); //2.设置字符集 mysqli_set_charset(数据库服务器对象,要设置的编码类型);
mysqli_set_charset($link,'utf8'); //3.选择数据库 mysqli_select_db(数据库服务器对象,数据库服务器中的指定的数据库名);
mysqli_select_db($link,'lamp183'); //4.输入增、删、改、查sql语句,并发送执行 mysqli_query(数据库服务器对象,sql语句);
$sql = 'select * from stu';
$result = mysqli_query($link,$sql);
var_dump($result); //5.解析结果集 mysqli_num_rows(query发送sql语句之后的对象结果集),会得到查询出数据的总条数;
if($result!=false && mysqli_num_rows($result)>0){ //遍历获取每一条数据的数组 mysqli_fetch_assoc(query发送sql语句之后的对象结果集),会得到每一条数据的数组
while($rows = mysqli_fetch_assoc($result)){
var_dump($rows);
}
} //6.关闭数据库,释放结果集
mysqli_free_result($result);
mysqli_close($link);
//六脉神剑操作数据库 //1.连接数据库服务器,并判断
$link = mysqli_connect('localhost','root','')or die('数据库连接失败!'); //2.设置字符集
mysqli_set_charset($link,'utf8'); //3.选择数据库
mysqli_select_db($link,'lamp183'); //4.定义增、删、改sql语句,并发送执行 //定义添加数据的sql语句(发送之后返回布尔型真或假)
$sql = "insert into stu (name) values ('jingfei')";
$bool = mysqli_query($link,$sql); //获取上一条插入成功的数据的id号
$id = mysqli_insert_id($link); //定义删除数据的sql语句
$sql = "delete from stu where id=2";
$bool = mysqli_query($link,$sql); //定义修改数据的sql语句
$sql = "update stu set name='haibo' where name='haibo'";
$bool = mysqli_query($link,$sql); //5.判断是否执行成功 mysqli_affected_rows(对象结果集):返回增删改sql语句执行成功之后的影响行数,如果失败返回-1
if($bool!=false && mysqli_affected_rows($link)>0){
echo "<script>alert('恭喜,添加成功!');window.location.href='3.php'</script>";
} //6.关闭数据库
mysqli_close($link);
【php】php操作MySQL数据库的更多相关文章
- PHP操作MySQL数据库5个步骤
PHP操作MySQL数据库一般可分为5个步骤:1.连接MySQL数据库服务器:2.选择数据库:3.执行SQL语句:4.关闭结果集:5断开与MySQL数据库服务器连接. 1.用mysql_connect ...
- python操作mysql数据库的相关操作实例
python操作mysql数据库的相关操作实例 # -*- coding: utf-8 -*- #python operate mysql database import MySQLdb #数据库名称 ...
- 转 用C API 操作MySQL数据库
用C API 操作MySQL数据库 参考MYSQL的帮助文档整理 这里归纳了C API可使用的函数,并在下一节详细介绍了它们.请参见25.2.3节,“C API函数描述”. 函数 描述 mysql_a ...
- PHP操作mysql数据库:[2]查询数据听语音
本文主要详细讲解如何使用php语言,对mysql数据库进行查询.添加.删除.更新等操作. 工具/原料 Macromedia Dreamweaver 8 mysql数据库,php语言 一.前言 ...
- Code First操作Mysql数据库
前面博客也讲了,自己做一个网站,选用的是MVC+EF Code First+MySql+EasyUI,先说下技术选型.一.为什么选择MVC? 因为之前自己做的系统大部分是webForm,MVC的之前也 ...
- JDBC操作MySQL数据库案例
JDBC操作MySQL数据库案例 import java.sql.Connection; import java.sql.DriverManager; import java.sql.Prepared ...
- shell脚本操作mysql数据库
shell脚本操作mysql数据库,使用mysql的-e参数可以执行各种sql的(创建,删除,增,删,改.查)等各种操作 mysql -hhostname -Pport -uusername -pp ...
- Java使用Jdbc操作MySql数据库(一)
这个示例是Java操作MySql的基本方法. 在这个示例之前,要安装好MySql,并且配置好账户密码,创建一个logininfo数据库,在数据库中创建userinfo数据表.并且在表中添加示例数据. ...
- 使用node js 操作 Mysql 数据库
使用node js 操作 Mysql 数据库 http://www.nodejs.org/ //node js 数据库操作 MySQL //使用https://github.com/felixge/n ...
- 批处理操作mysql数据库
批处理操作mysql数据库 1.使用批处理自动登录mysql数据库 @echo offcd C:\program files\mysql\mysql server 5.5\binmysql -u ro ...
随机推荐
- MySQL 整体架构一览
MySQL 在整体架构上分为 Server 层和存储引擎层.其中 Server 层,包括连接器.查询缓存.分析器.优化器.执行器等,存储过程.触发器.视图和内置函数都在这层实现.数据引擎层负责数据的存 ...
- javaScript 基础知识汇总(七)
1.数组 特点:数组是可以存储有序集合的对象. 声明: let arr = new Array(); let arr=[]; 大多数情况下我们使用第二种. let fruits = [" ...
- linux 执行计划任务crontab
crontab 一些常用的命令 service crond start //启动服务 service crond stop //关闭服务 service crond restart //重启服务 se ...
- 042.集群网络-flannel及calico
一 Flannel组件 1.1 flannel介绍 Kubernetes的网络模型假定了所有Pod都在一个可以直接连通的扁平网络空间中.若需要实现这个网络假设,需要实现不同节点上的Docker容器之间 ...
- 74. pNextID、pNextVal、pNID的区别
pNextID是平台调用单个新增组件的时候调用的: pNextVal是平台批量新增的时候调用: pNID应该是自己写的 :
- Kubernetes中Pod健康检查
目录 1.何为健康检查 2.探针分类 2.1.LivenessProbe探针(存活性探测) 2.2.ReadinessProbe探针(就绪型探测) 3.探针实现方法 3.1.Container Exe ...
- 【WebGL】WebGL API 详解
基于 WebGL Specifications 最全面的API释疑. 类型以及对象定义 这部分内容主要定义一部分类型和数据结构. typedef unsigned long GLenum; typed ...
- jupyter之配置自己喜欢的python环境
之前安装anaconda,会自动安装jupyer笔记本,但是本人从来没有用过,近期查看github上的一些教程时,发现很多文件都是.ipynb为后缀的jupyter文件,于是自己准备琢磨一下把环境换成 ...
- CF1324E Sleeping Schedule 题解
原题链接 简要题意: 每次可以将 \(a_i\) 减 \(1\) 或不变.求让 \(a_i\) 的前缀和 \(\% h\) 的值在 \([l,r]\) 区间中的最多的个数. E题是个水dp,也不怎样 ...
- Hive常用命令及作用
1-创建表 -- 内部表 create table aa(col1 string,col2 int) partitioned by(statdate int) ROW FORMAT DELIMITED ...