Mysqli面向过程连接
Posted 我的世界开始下雪
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mysqli面向过程连接相关的知识,希望对你有一定的参考价值。
Myslqi扩展
连接数据库模板
<?php
/* Connect to a mysql server 连接数据库服务器 */
$link = mysqli_connect(
\'localhost\', /* The host to connect to 连接MySQL地址 */
\'jian\', /* The user to connect as 连接MySQL用户名 */
\'123456\', /* The password to use 连接MySQL密码 */
\'jian\'); /* The default database to query 连接数据库名称*/
)
if (!$link) {
printf("Can\'t connect to MySQL Server. Errorcode: %s ", mysqli_connect_error());
exit;
}else
echo \'数据库连接上了!\';
/* Close the connection 关闭连接*/
mysqli_close($link);
?>
数据库连接的天龙八步:
1、连接数据库
连接:mysqli_connect
2、成功与否判断
连接错误号:mysqli_connect_errno
连接错误信息:mysqli_connect_error
3、选择数据库
选择库:mysqli_select_db
执行错误号:mysqli_errno
执行错误信息:mysqli_error
4、设置字符集
mysqli_set_charset
5、准备SQL语句
说明:符合SQL语法的任意语句
6、执行SQL语句
执行:mysqli_query
7、处理数据
查询时返回查询到数据行数:mysqli_num_rows
数据操作是影响的行数:mysqli_affected_rows
mysqli_fetch_row:获取一条数据的索引数组
mysqli_fetch_assoc:获取一条数据的关联数组
mysqli_fetch_array:获取一条数据的指定数组,
mysqli_fetch_all:获取结果集中的所有数据,
类型取决于第二个参数
第二个参数:MYSQLI_NUM(索引数组)
MYSQLI_ASSOC(关联数组)
MYSQLI_BOTH(索引和关联都有)
8、释放资源、关闭连接
释放资源:mysqli_free_result
关闭连接:mysqli_close
示例:
// 1、连接数据库
$link = @mysqli_connect(\'localhost\',\'root\',\'123456\');
// 2、成功与否判断
if (!$link) {
exit(\'error(\'.mysqli_connect_errno().\'):\'.mysqli_connect_error());
//die 该函数是 exit() 函数的别名。
}
// 3、选择数据库
if (!mysqli_select_db($link,\'test\')) {
echo \'error(\'.mysqli_errno($link).\'):\'.mysqli_error($link);
mysqli_close($link);
die;
}
// 4、设置字符集
mysqli_set_charset($link,\'utf8\');
设置从数据库服务器发送数据到数据库服务器时使用的默认字符集。
// 5、准备SQL语句
$sql = \'select * from star where id > 100\';
// 6、执行SQL语句
$result = mysqli_query($link,$sql);
if ($result && mysqli_num_rows($result)) {
// 7、处理数据
/
mysqli_fetch_row:获取一条数据的索引数组
mysqli_fetch_assoc:获取一条数据的关联数组
mysqli_fetch_array:获取一条数据的指定数组,
类型取决于第二个参数
mysqli_fetch_all:获取结果集中的所有数据,
类型取决于第二个参数
第二个参数:MYSQLI_NUM(索引数组)
MYSQLI_ASSOC(关联数组)
MYSQLI_BOTH(索引和关联都有)
var_dump(mysqli_fetch_all($result,MYSQLI_ASSOC));
/
while ($row = mysqli_fetch_array($result,MYSQLI_NUM)) {
var_dump($row);
}
} else {
}
// 8、释放资源、关闭连接
mysqli_free_result($result);
mysqli_close($link);
具体实现
//连接数据库操作
//连接数据库,并通过$link保存链接
$link = mysqli_connect(\'localhost\',\'root\',\'\',\'project5\');
Mysqli_connect(主机名/IP,用户名,密码,数据库名,端口号,socket通信);
Mysqli_connect 函数有六个参数,当省略参数时自动使用php.ini中配置的默认值
当数据库连接失败时,mysqli_connect提示的错误信息并不友好。可以通过下面的方式解决
$link = @mysqli_connect(\'localhost\',\'root\',\'\',\'project5\') or exit(\'数据库连接失败\');
@用于屏蔽错误信息,or是比较运算符,只有当左边表达式为false时才会执行右边的表达式,‘exit’用于停止脚本,同时可以输出错误信息。
当需要详细信息时,可以通过mysqli_connect_error()函数获取。
下面我用两种方式打印保存的连接$link
echo "<pre>";
print_r($link);
var_dump($link);
在使用命令行工具操作数据库时,需要使用SET NAMES 设置字符集
在PHP中也需要设置字符集
mysqli_set_charset() 函数规定当与数据库服务器进行数据传送时要使用的默认字符集。
mysqli_set_charset($link,\'utf8\'); //成功返回true失败返回false
只有保持PHP脚本文件、web服务器返回的编码、网页的<meta>标记、PHP访问Mysql使用的字符集集多统一时才能避免中文乱码问题。
https://www.jb51.net/article/22501.htm(具体文档)
php页面为utf编码
header("Content-type: text/html;
charset=utf-8");
<meta charset="UTF-8">//网页为uft8编码
设置查询的数据为utf8字符集(set names utf8同时设置客户端字符集,连接层字符集和查询结果(如结果集或错误消息)返回给客户端的字符集)
mysqli_query($link,"set names utf8");//PHP访问Mysql使用的字符集
mysqli_query() 函数执行某个针对数据库的查询
mysqli_set_charset和SET NAMES优劣分析(mysqli_set_charset除了做了”SET NAMES”以外, 还多做了一步)所有最好用mysqli_set_charset(详情请看下面链接的文章http://www.laruence.com/2010/04/12/1396.html).
https://blog.csdn.net/zhangfeng1133/article/details/46777883
$link = @mysqli_connect(\'localhost\',\'root\',\'\',\'project5\') or exit(\'数据库连接失败\'); //数据库连接结果
mysqli_set_charset($link,\'utf8\'); //成功返回true失败返回false
mysqli_query($link,\'use news\'); //选择数据库(SQL语句方式)
mysqli_query($link,\'set names utf8\'); //设置字符集(SQL语句方式)
//执行SQL语句,并获取结果集
$result = myslqi_query($link,\'show databases\');
if(!$result){
exit(\'执行失败。错误信息:\'.mysqli_error($link));
}
echo "<pre>";
print_r($result);
var_dump($result);
//处理结果集$result
mysql_num_rows($result) 从结果集中获取数据记录的个数
mysql_num_fields($result) 从结果集中获取数据记录列的个数
mysql_fetch_row() 该函数将一条结果记录返回,并以一个普通索引数组的形式保存
mysql_fetch_assoc() 该函数将一条结果记录返回,并以一个普通关联数组形式保存
mysql_fetch_array() 默认同时以索引数组和关联数组保存,三个参数MYSQL_ASSOC, MYSQL_NUM, MYSQL_BOTH
mysql_fetch_object() 以一个对象的形式返回一条结果记录,他的各个字段需要以对象的形式进行访问
var_dump(mysqli_num_rows($result));(从结果集中获取数据记录的个数;结果如下)
H:\\wamp\\www\\test\\test.php:48:int 6
var_dump(mysqli_fetch_all($result)); //获取所有结果,并以数组方式返回
print_r(mysqli_fetch_all($result)); //这种方式看的比较直观
总结:
var_dump(mysqli_fetch_array($result));
var_dump(mysqli_fetch_assoc($result));
var_dump(mysqli_fetch_row($result));
从结果集中获取数据记录的个数
以上是关于Mysqli面向过程连接的主要内容,如果未能解决你的问题,请参考以下文章