前端PHP入门-033-连接数据库-天龙八步
php检查MySQL的支持是否开启?
若没有看到mysqli扩展在windows服务器下,打开php.ini文件,将php_mysqli.dll打开即可!
注意:
从PHP7开始默认不再支持mysql扩展,即不再支持mysql_*系列函数。请使用mysqli连接数据库。
mysqli即支持php5也支持php7。
数据库连接天龙八步
第一步: 连接数据库服务器
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_connect |
| 功能 | 连接到mysql数据库服务器 |
| 参数1 | 主机 |
| 参数2 | 数据库服务器登陆名 |
| 参数3 | 密码 |
| 参数4 | 数据库的名称 |
| 参数5 | 数据库服务器端口不填默认3306 |
若参数4,数据库名称在此步已填并择,不需要执行第三步。
第二步: 判断错误
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_errno |
| 功能 | 返回连接错误号,无错误返回0 |
| 参数1 | 传入mysqli_connect返回的资源 |
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_error |
| 功能 | 返回连接错误字符串 |
| 参数1 | 传入mysqli_connect返回的资源 |
第三步: 选择数据库
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_select_db |
| 功能 | 选择本连接中的数据库 |
| 参数1 | 传入mysqli_connect返回的资源 |
| 参数2 | 需要连接的数据库名 |
若在第一步已填数据库,不需要更换成其他数据库,则不需要执行第三步。
第四步: 设置字符集
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_set_charset |
| 功能 | 设置与mysql服力器连接,结果,校验字符集 |
| 参数1 | 传入mysqli_connect返回的资源 |
| 参数2 | 字符集类型 |
第五步: 准备SQL语句
其实就是一个SQL语句的字符串。
例如:
sql="insertintouser(username,password)values(′" role="presentation" style="position: relative;">sql="insertintouser(username,password)values(′sql="insertintouser(username,password)values(′username','$password')";
我们通常要把变量赋值在SQL语句中使用。可是变量或者SQL语句出错了,非常不好排查。
我们根据实际工作经验增加了这一步。
如果在执行此步的时候报错了,我们可以把SQL语句打印出来,粘贴到phpMyAdmin或者相关工具中。
排错时,如果执行成功就说明不是SQL语句的问题。如果执行失败,请仔细检查SQL语句。
第六步: 发送SQL语句
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_query |
| 功能 | 发送SQL语句 |
| 参数1 | 传入mysqli_connect返回的资源 |
| 参数2 | 传入发送的SQL语句 |
SQL语句准备完成,需要通过mysqli_query将SQL语句发送给MySQL服务器。
MySQL服务器会执行发送过来的SQL语句进行执行。
第七步: 判断是否执行正常或者遍历数据
读取
第6步中,发送的是select类别的语句,通常需要将结果输出显示出来。就需要用到遍历显示数据的函数。
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_fetch_array |
| 功能 | 得到result结果集中的数据,返回数组进行遍历 |
| 参数1 | 传入查询出来的结果变量 |
| 参数2 | 传入MYSQLI_NUM返回索引数组,MYSQLI_ASSOC返回关联数组,MYSQLI_BOTH返回索引和关联 |
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_fetch_assoc |
| 功能 | 得到result结果集中的数据,返回关联数组进行便利 |
| 参数1 | 传入查询出来的结果变量 |
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_fetch_row |
| 功能 | 得到result结果集中的数据,返回索引数组进行便利 |
| 参数1 | 传入查询出来的结果变量 |
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_fetch_object |
| 功能 | 得到result结果集中的数据,返回对象进行遍历 |
| 参数1 | 传入查询出来的结果变量 |
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_num_rows |
| 功能 | 返回查询出来的结果总数 |
| 参数1 | 传入查询出来的结果变量 |
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_num_rows |
| 功能 | 返回查询出来的结果总数 |
| 参数1 | 传入查询出来的结果变量 |
| 注 | 实际工作中用得非常少,了解 |
写入
第6步中,如果发送的是insert的语句,通常需要得到是否执行成功,或者同时拿到自增的ID。
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_fetch_field |
| 功能 | 遍历数据行 |
| 参数1 | 传入查询出来的结果变量 |
修改和删除
第6步中,如果发送的是update和delete类别的语句。只需要判断是否执行成功即可。
我们将这些常用函数列出数据表给给大家查看。
第八步: 关闭数据库
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_close |
| 功能 | 关闭数据库连接 |
| 参数1 | 传入mysqli_connect返回的资源 |
数据库连接是一个资源类型。我们在之前的章节中讲解资源类型的时候跟大家说过。凡是涉及到数资源类型的有打开就有关闭。这样能够保证PHP更高效的处理和回收资源。
因此,数据库连接成功后,不需要使用的时候。我们可以关闭这个连接。
其他:显示服务器信息函数
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_get_server_info |
| 功能 | 返回服务器信息 |
| 参数1 | 传入mysqli_connect返回的资源 |
| 类型 | 说明 |
|---|---|
| 函数 | mysqli_get_server_version |
| 功能 | 返回服务器版本 |
| 参数1 | 传入mysqli_connect返回的资源 |
注意:PDO的连接方式才是王道
mysqli只学过程化的方法即可。在面向对象阶段实际工作中完全抛弃了mysqli的对象用法,而是使用的是PDO对象连接数据库的方式。
前端PHP入门-033-连接数据库-天龙八步的更多相关文章
- MySQL原生PHP操作-天龙八步
<?php //1.第一步[建立连接] $conn = mysqli_connect('localhost','root','123456') or die('数据库连接失败!'); //2.第 ...
- 前端基础:”天龙八步“细说浏览器输入URL后发生了什么
参考:https://www.xuecaijie.com/it/157.html#1Q64p5DeC8dKFF 本文摘要: 1.DNS域名解析: 2.建立TCP连接: 3.发送HTTP请求: 4.服务 ...
- 天龙八步"细说浏览器输入URL后发生了什么
本文摘要: 1.DNS域名解析: 2.建立TCP连接: 3.发送HTTP请求: 4.服务器处理请求: 5.返回响应结果: 6.关闭TCP连接: 7.浏览器解析HTML: 8.浏览器布局渲染: 总结 输 ...
- “天龙八步”细说浏览器输入URL后发生了什么
本文摘要: 1.DNS域名解析: 2.建立TCP连接: 3.发送HTTP请求: 4.服务器处理请求: 5.返回响应结果: 6.关闭TCP连接: 7.浏览器解析HTML: 8.浏览器布局渲染: 总结 输 ...
- Web前端小白入门指迷
前注:这篇文章首发于我自己创办的服务于校园的技术分享 [西邮 Upper -- 004]Web前端小白入门指迷,写得很用心也就发在这里. 大前端之旅 大前端有很多种,Shell 前端,客户端前端,Ap ...
- openresty 前端开发入门五之Mysql篇
openresty 前端开发入门五之Mysql篇 这章主要演示怎么通过lua连接mysql,并根据用户输入的name从mysql获取数据,并返回给用户 操作mysql主要用到了lua-resty-my ...
- 每天成长一点---WEB前端学习入门笔记
WEB前端学习入门笔记 从今天开始,本人就要学习WEB前端了. 经过老师的建议,说到他每天都会记录下来新的知识点,每天都是在围绕着这些问题来度过,很有必要每天抽出半个小时来写一个知识总结,及时对一天工 ...
- 使用 gulp 搭建前端环境入门篇(转载)
本文转载自: 使用 gulp 搭建前端环境入门篇
- Bootstrap入门(二十八)JS插件5:工具提醒
Bootstrap入门(二十八)JS插件5:工具提醒 工具提示在使用过程中比较常见,但是实现起来有些麻烦,而bootstrap则很好地解决了这个问题. 我们来写一个简单的实例 先引入CSS文件和JS文 ...
随机推荐
- lambda(匿名函数)---基于python
在学习python的过程中,lambda的语法时常会使人感到困惑,lambda是什么,为什么要使用lambda,是不是必须使用lambda? 下面就上面的问题进行一下解答. 1.lambda是什么? ...
- php命名空间学习笔记。
为什么要用命名空间? 在PHP中,命名空间用来解决在编写类库或应用程序时创建可重用的代码如类或函数时碰到的两类问题: 用户编写的代码 与 PHP内部的类/函数/常量或第三方类/函数/常量之间的名字冲 ...
- ubuntu16.04卸载火狐,Amazon
一.卸载火狐: . dpkg --get-selections |grep firefox .sudo apt-get purge firefox unity-scope-firefoxbookmar ...
- 目标跟踪之Lukas-Kanade光流法(转)
光流是图像亮度的运动信息描述.光流法计算最初是由Horn和Schunck于1981年提出的,创造性地将二维速度场与灰度相联系,引入光流约束方程,得到光流计算的基本算法.光流计算基于物体移动的光学特性提 ...
- 可以从Jar外部加载JDBC.properties的Spring-mybatis配置文件
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...
- PreparedStatement的execute误解
boolean execute() throws SQLException在此 PreparedStatement 对象中执行 SQL 语句,该语句可以是任何种类的 SQL 语句.一些特别处理过的语 ...
- 【一】shiro入门 之 Shiro简介
Shiro 可以非常容易的开发出足够好的应用,其不仅可以用在JavaSE 环境,也可以用在JavaEE 环境.Shiro 可以帮助我们完成:认证.授权.加密.会话管理.与Web 集成.缓存等.这不就是 ...
- BZOJ4977 跳伞求生(贪心)
如果现在选定了一些要求消灭的敌人而不考虑积分,显然应该让每个敌人被刚好能消灭他的人消灭.再考虑最大化积分,显然我们应该优先消灭ci-bi大的敌人,所选用的a也应尽量大.于是按ci-bi从大到小排序,用 ...
- Contest 5
A:这我怎么没学傻了啊.整个一傻逼题一眼容斥我连暴力都写不出来啊.显然序列是没有什么用的,考虑求众数小于x的概率,显然可以枚举有几个超过容斥一发.虽然要算的组合数非常大,发现可以抵消很大一部分,最后算 ...
- [BZOJ2432][Noi2011]兔农 矩阵乘法+exgcd
2432: [Noi2011]兔农 Time Limit: 10 Sec Memory Limit: 256 MB Description 农夫栋栋近年收入不景气,正在他发愁如何能多赚点钱时,他听到 ...