1.简介
PHP连接数据库有多种方法,现介绍常用的MysqL数据库连接方法,PHP连接MysqL也有两种方式,一是面向对象,二是面向过程方式,两种方法稍有区别。下面通过代码介绍两种方法连接MysqL并以json格式输出。
2、面向对象方式
$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.面向过程方式
// 创建连接
$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示例
5.json输出说明
由于$row = MysqLi_fetch_array($result)获取数据的一行数据并以数组形式存储,里边除了字段和值键值对外默认还会有0,1,2……下标存在,如下所示
如此数据就出现冗余,unset方法则是删除数组冗余数据,之后再添加到$arr数组中。 另外在json编码中json_encode($arr);会出现中文被unicode编码,PHP5.3加入了options参数, 5.4以后才加入JSON_UnesCAPED_UNICODE,这个参数,不需要做escape和unicode处理。所以在5.4之前都需要对中文做个处理 。5.4里面直接补上代码中的参数即可。
整理网上的方法,5.4之前处理方法有两种,方法1:在实际应用中有个问题,部分字符会掉,原因暂不清楚。
方法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)面向过程连接数据库:
"; print_r($row); ?>
(2)面向对象的数据库连接
'; print_r($row); /* free result set */ $result->free(); /* close connection */ $MysqLi->close(); >
这篇文章就介绍到这了,关于PHP连接MysqL数据库并以json格式输出的实现代码,需要的朋友可以参考一下。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。