1.简介
PHP连接数据库有多种方法,现介绍常用的MySQL数据库连接方法,PHP连接MySQL也有两种方式,一是面向对象,二是面向过程方式,两种方法稍有区别。下面通过代码介绍两种方法连接MySQL并以json格式输出。
2、面向对象方式
<?php header("content-Type: text/html; charset=utf-8");//字符编码设置 $servername = "localhost"; $username = "root"; $password = "123456"; $dbname = "mydb"; // 创建连接 $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.面向过程方式
<?php header("content-Type: text/html; charset=utf-8");//字符编码设置 $servername = "localhost"; $username = "root"; $password = "123456"; $dbname = "mydb"; // 创建连接 $con =mysqli_connect($servername, $username, $password, $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示例
[{"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……下标存在,如下所示
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:在实际应用中有个问题,部分字符会掉,原因暂不清楚。
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 encode_json($str) { return urldecode(json_encode(url_encode($str))); } /** * */ 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)面向过程连接数据库:
<!-- 面向过程的数据库mysqli连接 --> <?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 "<pre>"; print_r($row); ?>
(2)面向对象的数据库连接
<!-- 面向对象的数据库mysqli连接 --> lt;?php $mysqli=new mysqli("localhost","root","950609","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 '<pre>'; print_r($row); /* free result set */ $result->free(); /* close connection */ $mysqli->close(); >
这篇文章就介绍到这了,关于PHP连接MySQL数据库并以json格式输出的实现代码,需要的朋友可以参考一下。
问题内容: MySQL将日期存储在数据库中(默认情况下)为“ YYYY-MM-DD”。日期的字段类型为“ DATE”(我不需要任何时间存储)。是否有一种简单的方法可以默认更改日期到DD / MM / YYYY吗? 我在2个不同的表中调用了不同的日期,并且在我的任何代码中都没有类似日期变量的内容或任何东西!希望这是一个直接的改变? 问题答案: 在PHP中,您可以: 使用以下命令将日期转换为时间戳 使
我正在尝试连接我的android应用程序,该应用程序使用php将登录页面连接到数据库。它正在连接到数据库。但它并不是从表中检索所有列。相反,只获取两个冒号。下面是代码 请帮我解决这个问题。 这里是登录表单的PHP代码 我的logcat显示以下错误。 但它显示点击提交按钮后停止工作,我需要检索数据显示在Android模拟器上 包com。实例主要的导入java。木卫一。缓冲读取器;导入java。木卫一
本文我们为大家介绍 Python3 使用 PyMySQL 连接数据库,并实现简单的增删改查。 什么是 PyMySQL? PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb。 PyMySQL 遵循 Python 数据库 API v2.0 规范,并包含了 pure-Python MySQL 客户端库。 PyMySQL 安装 在使用
问题内容: 我试图从一个类中的数据库获取用户ID,但是我对类的经验很少甚至没有,我该如何从数据库中获取uid并返回uid? 所以基本上是这样的 就像我说的,我还是新手,所以任何建议或帮助都将不胜感激! 提前感谢! 问题答案: 首先构建一个MySQL类库…满足以下示例中的要求: 和配置文件…
本文向大家介绍java连接mysql数据库 java连接sql server数据库,包括了java连接mysql数据库 java连接sql server数据库的使用技巧和注意事项,需要的朋友参考一下 在java的应用中,我们经常会对数据库进行必要的操作,下来我们就了解一下如何用java连接mysql数据库 以及java连接sql server数据库 一、mysql 二、sql server 以上就
我正在尝试连接一个PHP脚本和一个数据库。但我总是犯同样的错误。 致命错误:未捕获错误:调用未定义的函数mysql_connect()在C:\xampp\htdocs\Datenbank\login.php:12堆栈跟踪:#0{main}抛出在第12行的C:\xampp\htdocs\Datenbank\login.php 这一错误发生在第12行。 但我做错了什么? 谢谢你的帮助。