微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

相关推荐