PHP连接MySQL数据库并以json格式输出

1.简介

PHP连接数据库有多种方法,现介绍常用的MysqL数据库连接方法PHP连接MysqL也有两种方式,一是面向对象,二是面向过程方式,两种方法稍有区别。下面通过代码介绍两种方法连接MysqL并以json格式输出

2、面向对象方式

rush:PHP;"> // 创建连接
$conn =new mysqli($servername,$username,$password,$dbname);
// 检测连接
if ($conn->connect_error) {
die("Connection Failed: " . $conn->connect_error);
}

$sql = "SELECT * FROM power WHERE DATE='2014-1-1'";
$result = $conn->query($sql);

$arr = array();
// 输出每行数据
while($row = $result->fetch_assoc()) {
$count=count($row);//不能在循环语句中,由于每次删除row数组长度都减小
for($i=0;$i<$count;$i++){
unset($row[$i]);//删除冗余数据
}
array_push($arr,$row);

}
//print_r($arr);
echo json_encode($arr,JSON_UNESCAPED_UNICODE);//json编码
$conn->close();

?>

3.面向过程方式

rush:PHP;"> PHP header("content-Type: text/html; charset=utf-8");//字符编码设置 $servername = "localhost"; $username = "root"; $password = "123456"; $dbname = "mydb";

// 创建连接
$con =MysqLi_connect($servername,$dbname);
// 检测连接
if (MysqLi_connect_errno())
{
echo "Failed to connect to MysqL: " . MysqLi_connect_error();
}

$sql = "SELECT * FROM power WHERE DATE='2014-1-1'";
$result = MysqLi_query($con,$sql);

$arr = array();
while($row = MysqLi_fetch_array($result)) {
$count=count($row);//不能在循环语句中,由于每次删除 row数组长度都减小
for($i=0;$i<$count;$i++){
unset($row[$i]);//删除冗余数据
}

array_push($arr,$row);

}
echo json_encode($arr,JSON_UNESCAPED_UNICODE);
mysqli_close($con);

?>

4.输出json示例

rush:js;"> [{"NAME":"小区1","DM":"A","LNG":"564142.623","LAT":"4329376.169","DATE":"2014-1-1","VAL":"26.8"},{"NAME":"小区2","DM":"B","LNG":"563089.677","LAT":"4329311.017","VAL":"26.8"}]

5.json输出说明

由于$row = MysqLi_fetch_array($result)获取数据的一行数据并以数组形式存储,里边除了字段和值键值对外认还会有0,1,2……下标存在,如下所示

小区1 [NAME] => 小区1 [1] => A [DM] => A [2] => 564142.623 [LNG] => 564142.623 [3] => 4329376.169 [LAT] => 4329376.169 [4] => 2014-1-1 [DATE] => 2014-1-1 [5] => 26.8 [VAL] => 26.8 )

如此数据就出现冗余,unset方法则是删除数组冗余数据,之后再添加到$arr数组中。 另外在json编码中json_encode($arr);会出现中文被unicode编码,PHP5.3加入了options参数, 5.4以后才加入JSON_UnesCAPED_UNICODE,这个参数,不需要做escape和unicode处理。所以在5.4之前都需要对中文做个处理 。5.4里面直接补上代码中的参数即可。

整理网上的方法,5.4之前处理方法有两种,方法1:在实际应用中有个问题,部分字符会掉,原因暂不清楚。

rush:PHP;"> function encode_json($arr){ $code = json_encode($arr); return preg_replace("#\\\u([0-9a-f]+)#ie","iconv('UCS-2','UTF-8',pack('H4','\\1'))",$code); }

方法2:先对需要处理的做urlencode处理,然后json_encode,最后做urldecode处理

/**

  • */
    function url_encode($str) {
    if(is_array($str)) {
    foreach($str as $key=>$value) {
    $str[urlencode($key)] = url_encode($value);
    }
    } else {
    $str = urlencode($str);
    }

return $str;
}

MysqLi连接MysqL数据库的常用方法(面向对象和面向过程)

相信开始学习PHP的伙伴们用的都是PHP4,或者PHP5,在这些版本中都有一个连接数据库函数MysqL_connect(),但在使用PHP5.5及5.5以上版本时,你会发现使用MysqL_connect()会直接报错,这是因为PHP5.5以后的版本考虑到未来的可移植性和安全性,性能而废弃了MysqL_connect()函数,所以我们只能使用MysqLi_connect()和PDO,这里我说一下MysqLi_connect()。

MysqLi_connect()的两种方式,面向过程和面向对象的连接数据库方法

(1)面向过程连接数据库

rush:PHP;"> PHP $conn=MysqLi_connect("localhost","root","950609","user"); // 连接数据库user if (!$conn) { # code...判断链接是否成功 echo "连接失败!"; echo MysqLi_connect_error(); exit(); } MysqLi_query($conn,"set names utf8"); // 指定编码格式 $sql="select * from goods"; // sql语句 $result=MysqLi_query($conn,$sql); // 执行sql语句,将执行结果返回到结果集中 $row=MysqLi_fetch_array($result); // 从结果集中取得一行作为数组 echo "
"; 
  print_r($row); 
?> 

(2)面向对象的数据库连接

rush:PHP;"> lt;?PHP $MysqLi=new MysqLi("localhost","user"); if ( $MysqLi -> connect_error ) { die( 'Connect Error (' . $MysqLi -> connect_errno . ') ' . $MysqLi -> connect_error ); } $sql = "select * from goods"; $MysqLi->set_charset("utf8"); $result = $MysqLi->query($sql); $row = $result->fetch_array(); // 从结果集中取得一行作为数组 echo '
'; 
  print_r($row);  
  /* free result set */  
  $result->free();  
  /* close connection */  
  $MysqLi->close();  
> 

这篇文章就介绍到这了,关于PHP连接MysqL数据库并以json格式输出的实现代码,需要的朋友可以参考一下。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返回预支付订单号的接口,目前微信支付所有场景均使用这一接口。下面介绍的是其中NATIVE的支付实现流程与PC端实现扫码支付流程
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返回预支付订单号的接口,目前微信支付所有场景均使用这一接口。下面介绍的是其中APP的支付的配置与实现流程
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户信息这个功能的开发流程。 配置 1.首先得在微信公众平台申请一下微信小程序账号并获取到小程序的AppID和AppSecret https://mp.weixin.qq.com/cgi-bin/loginpage?url=%2Fwxamp%2F
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一款开源且免费商用的后台开发框架,它基于ThinkPHP和Bootstrap两大主流技术构建的极速后台开发框架,它有着非常完善且强大的功能和便捷的开发体验,使我逐渐喜欢上了它。
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛,就离不开通讯了,然后我就想到了长连接。这里本人用的是GatewayWorker框架。
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返回预支付订单号的接口,目前微信支付所有场景均使用这一接口。下面介绍的是其中JSAPI的支付实现流程
服务器优化必备:深入了解PHP8底层开发原理
Golang的网络编程:如何快速构建高性能的网络应用?
Golang和其他编程语言的对比:为什么它的开发效率更高?
PHP8底层开发原理揭秘:如何利用新特性创建出色的Web应用
将字符重新排列以形成回文(如果可能)在C++中
掌握PHP8底层开发原理和新特性:创建高效可扩展的应用程序
服务器性能优化必学:掌握PHP8底层开发原理
PHP8新特性和底层开发原理详解:优化应用性能的终极指南
将 C/C++ 代码转换为汇编语言
深入研究PHP8底层开发原理:创建高效可扩展的应用程序
C++程序查找法向量和迹
PHP8底层开发原理实战指南:提升服务器效能
重排数组,使得当 i 为偶数时,arr[i] >= arr[j],当 i 为奇数时,arr[i] <= arr[j],其中 j < i,使用 C++ 语言实现
Golang的垃圾回收:为什么它可以减少开发人员的负担?