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 举报,一经查实,本站将立刻删除。

相关推荐


服务器优化必备:深入了解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的垃圾回收:为什么它可以减少开发人员的负担?
C++程序:将一个数组的所有元素复制到另一个数组中
Golang:构建智能系统的基石
为什么AI开发者应该关注Golang?
在C和C++中,逗号(comma)的用法是用来分隔表达式或语句
PHP8底层开发原理解析及新特性应用实例
利用PHP8底层开发原理解析新特性:如何构建出色的Web应用