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

来源:互联网 发布:jq 数组push键值对 编辑:程序博客网 时间:2024/06/05 09:26

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

标签: phpmysqljson
 980人阅读 评论(0) 收藏 举报
 分类:
   

1.简介

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

2、面向对象方式

[php] view plain copy
  1. <?php  
  2. header("content-Type: text/html; charset=utf-8");//字符编码设置  
  3. $servername = "localhost";  
  4. $username = "root";  
  5. $password = "123456";  
  6. $dbname = "mydb";  
  7.   
  8. // 创建连接  
  9. $conn =new mysqli($servername$username$password$dbname);  
  10. // 检测连接  
  11. if ($conn->connect_error) {  
  12.     die("Connection failed: " . $conn->connect_error);  
  13. }  
  14.   
  15. $sql = "SELECT * FROM power WHERE DATE='2014-1-1'";  
  16. $result = $conn->query($sql);  
  17.   
  18. $arr = array();  
  19. // 输出每行数据  
  20. while($row = $result->fetch_assoc()) {  
  21.     $count=count($row);//不能在循环语句中,由于每次删除row数组长度都减小  
  22.     for($i=0;$i<$count;$i++){  
  23.         unset($row[$i]);//删除冗余数据  
  24.     }  
  25.     array_push($arr,$row);  
  26.   
  27. }  
  28. //print_r($arr);  
  29. echo json_encode($arr,JSON_UNESCAPED_UNICODE);//json编码  
  30. $conn->close();  
  31.   
  32. ?>  
3.面向过程方式

[php] view plain copy
  1. <?php  
  2. header("content-Type: text/html; charset=utf-8");//字符编码设置  
  3. $servername = "localhost";  
  4. $username = "root";  
  5. $password = "123456";  
  6. $dbname = "mydb";  
  7.   
  8. // 创建连接  
  9. $con =mysqli_connect($servername$username$password$dbname);  
  10. // 检测连接  
  11. if (mysqli_connect_errno())  
  12. {  
  13.     echo "Failed to connect to MySQL: " . mysqli_connect_error();  
  14. }  
  15.   
  16. $sql = "SELECT * FROM power WHERE DATE='2014-1-1'";  
  17. $result = mysqli_query($con,$sql);  
  18.   
  19. $arr = array();  
  20. while($row = mysqli_fetch_array($result)) {  
  21.     $count=count($row);//不能在循环语句中,由于每次删除 row数组长度都减小  
  22.     for($i=0;$i<$count;$i++){  
  23.         unset($row[$i]);//删除冗余数据  
  24.     }  
  25.   
  26.     array_push($arr,$row);  
  27.   
  28. }  
  29. echo json_encode($arr,JSON_UNESCAPED_UNICODE);  
  30. mysqli_close($con);  
  31.   
  32. ?>  

4.输出json示例

[javascript] view plain copy
  1. [{"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","DATE":"2014-1-1","VAL":"26.8"}]  

5.json输出说明

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

[javascript] view plain copy
  1. Array ( [0] => 小区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:在实际应用中有个问题,部分字符会掉,原因暂不清楚。

[php] view plain copy
  1. function encode_json($arr){  
  2.     $code = json_encode($arr);  
  3.     return preg_replace("#\\\u([0-9a-f]+)#ie""iconv('UCS-2', 'UTF-8', pack('H4', '\\1'))"$code);  
  4. }  

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

[php] view plain copy
  1. function encode_json($str) {  
  2.     return urldecode(json_encode(url_encode($str)));      
  3. }  
  4.   
  5. /** 
  6.  *  
  7.  */  
  8. function url_encode($str) {  
  9.     if(is_array($str)) {  
  10.         foreach($str as $key=>$value) {  
  11.             $str[urlencode($key)] = url_encode($value);  
  12.         }  
  13.     } else {  
  14.         $str = urlencode($str);  
  15.     }  
  16.       
  17.     return $str;  
  18. }  
0 0
原创粉丝点击