PHP成长之路之PHP连接MySql数据库(一)
PHP(外文名:PHP: Hypertext Preprocessor,中文名:“超文本预处理器”)是一种通用开源脚本语言。语法吸收了C语言、Java和Perl的特点,利于学习,使用广泛,主要适用于Web开发领域。PHP 独特的语法混合了C、Java、Perl以及PHP自创的语法。它可以比CGI或者Perl更快速地执行动态网页。用PHP做出的动态页面与其他的编程语言相比,PHP是将程序嵌入到HTML(标准通用标记语言下的一个应用)文档中去执行,执行效率比完全生成HTML标记的CGI要高许多;PHP还可以执行编译后代码,编译可以达到加密和优化代码运行,使代码运行更快。
使用PHP连接MySql数据库具体操作:
<?php
/**
* 数据库连接文件
* Created by PhpStorm.
* User: DingChao
* Date: 2017/10/17
* Time: 16:02
*/ /*对应的参数1:本地,2:用户名3,密码*/
$conn = @mysql_connect("localhost", "****", "****");
if (!$conn) {
die("数据库链接失败:" . mysql_error);
}
mysql_select_db("phpdemo1", $conn);//参数2:数据库名称
//字符转换,读库
mysql_query("set character set 'utf-8'");
//写库
mysql_query("set names 'utf-8'");
?>
在要进行数据库连接查询数据时:
<?php
/**
* Created by PhpStorm.
* User: DingChao
* Date: 2017/10/19
* Time: 13:51
*/
/*防止乱码*/
header("Content-type: text/html; charset=utf-8");
//session_start();
//多表联查 inner join测试
include('conn.php'); /*根据传递的不同参数执行不同的方法*/
if (empty($_REQUEST['arg'])) {
/*拼接成功后返回的字符串*/
$resultJson = array(
'state' => 1,
'msg' => '缺少必要的参数',
'data' => ''
);
echo JSON($resultJson);
} else {
if ($_REQUEST['arg'] != '') {
if ($_REQUEST['arg'] == 'datajson') {
$sql = "select e.ename,e.ejob,d.dname from emp e INNER JOIN dept d on e.edid=d.did";
//$result = mysql_query('select e.ename,e.ejob,d.dname from emp e INNER JOIN dept d on e.edid=d.did');
$result = mysql_query($sql); /*创建数组用来接收多部门员工*/
$emp_dept = array();
if (mysql_num_rows($result) > 0) {
while ($row = mysql_fetch_assoc($result)) {
array_push($emp_dept, $row);
}
/*拼接成功后返回的字符串*/
$resultJson = array(
'state' => 0,
'msg' => '查询成功',
'data' => $emp_dept
);
// print_r(json_encode($resultJson));//打印json
echo JSON($resultJson);
} else {
/*拼接没有数据后返回的字符串*/
$resultJson = array(
'state' => 1,
'msg' => '暂时没有数据',
'data' => ''
);
// print_r(json_encode($resultJson));
echo JSON($resultJson);
}
}
} /*根据参数传递的不同值执行不同的方法*/
if (empty($_REQUEST['arg'])) $_REQUEST['arg'] = '';
if ($_REQUEST['arg'] != '') {
if ($_REQUEST['arg'] == 'argssss') {
echo 'efadfdfasdfsadfsdfas';
}
}
} /*处理链表查询中文为null的情况和JOSN配合使用*/
/**
* arrayRecursive方法对输出结果进行递归,把每一项用urlencode处理
* 在开始的时候,我们建立一个递归层数计数器,如果递归层数太深我们就放弃此次操作
* apply_to_keys_also 变量一般为false,我们在建立数据库时用的索引一般都是英文,故在这里并不用将数组的索引值也用urlencoding处理
* @param string &$array 要处理的字符串
* @param string $function 要执行的函数,我们将所有数据都用urlencode处理
* @param boolean $apply_to_keys_also 是否也应用到key上,因为key一般都为英文,故这里为false
*/ function arrayRecursive(&$array, $function, $apply_to_keys_also = false)
{
static $recursive_counter = 0;
if (++$recursive_counter > 1000) {
die('possible deep recursion attack');
}
foreach ($array as $key => $value) {
if (is_array($value)) {
arrayRecursive($array[$key], $function, $apply_to_keys_also);
} else {
$array[$key] = $function($value);
}
if ($apply_to_keys_also && is_string($key)) {
$new_key = $function($key);
if ($new_key != $key) {
$array[$new_key] = $array[$key];
unset($array[$key]);
}
}
}
$recursive_counter--;
} /**
* 首先对结果数组$array运行arrayRecursive,将所有内容进行urlencoding
* 接着对urlencode之后的数组进行JSON编码
* 最后再进行JSON解码,于是得到了我们需要的中文数据
* @param string &$array 要处理的字符串,这里是数据库中的数据
*/ function JSON($array)
{
arrayRecursive($array, 'urlencode', true);
$json = json_encode($array);
return urldecode($json);
}
PHP成长之路之PHP连接MySql数据库(一)的更多相关文章
- nodejs进阶(6)—连接MySQL数据库
1. 建库连库 连接MySQL数据库需要安装支持 npm install mysql 我们需要提前安装按mysql sever端 建一个数据库mydb1 mysql> CREATE DATABA ...
- PDO连接mysql数据库
1.PDO简介 PDO(PHP Data Object) 是PHP 5 中加入的东西,是PHP 5新加入的一个重大功能,因为在PHP 5以前的php4/php3都是一堆的数据库扩展来跟各个数据库的连接 ...
- Windows操作系统下远程连接MySQL数据库
用Eclipse做一个后台项目,但是数据库不想放在本地电脑,于是买了一个腾讯云服务器(学生有优惠,挺便宜的),装上MySQL数据库,但是测试连接的时候,发现总是连接不是上,但是本地数据库可以连接,于是 ...
- java 通过jdbc连接MySQL数据库
先了解下JDBC的常用接口 1.驱动程序接口Driver 每种数据库的驱动程序都应该提供一个实现java.sql.Driver接口的类,简称Driver类.通常情况下,通过java.lang.Clas ...
- JDBC连接MySQL数据库代码模板
下面这个例子是最简单的JDBC连接MySQL数据库的例子. 一般步骤: 1.注册驱动: 2.建立连接: 3.创建语句: 4.处理结果: 5.释放资源. 注意: 1.软件开发环境:MyEclipse 8 ...
- PHP如何连接MySQL数据库
* PHP连接MySQL数据库 * 准备工作 * 在XAMPP软件的安装目录/php/ext目录中 * php_mysql.dll和php_mysqli.dll文件必须存在 * 在XAMPP软件的安装 ...
- JSP连接MySQL数据库问题
之前写了一大段,还说了一下具体JDBC连接数据库API的具体包的基本知识,哪知道自己手残不小心按了删除按钮.结果去看自动保存记录时,就只剩下下面这段了.好吧,其实最主要最核心的也就是下面这点了.具体如 ...
- java连接mysql数据库详细步骤解析
java连接mysql数据库详细步骤解析 第一步:下载一个JDBC驱动包,例如我用的是:mysql-connector-java-5.1.17-bin.jar 第二步:导入下载的J ...
- Java连接MySQL数据库——含步骤和代码
工具:eclipse MySQL5.6 MySQL连接驱动:mysql-connector-java-5.1.27.jar 加载驱动: 1. 在工程目录中创建lib文件夹,将下载好的JDBC放到该文件 ...
随机推荐
- MXNet之ps-lite及parameter server原理
MXNet之ps-lite及parameter server原理 ps-lite框架是DMLC组自行实现的parameter server通信框架,是DMLC其他项目的核心,例如其深度学习框架MXNE ...
- Redis学习-内存优化
以下为个人学习Redis的备忘录--内存优化 1.随时查看info memory,了解内存使用状况:127.0.0.1:6379> info memory# Memoryused_memory: ...
- Redis 图形化监控方案 RedisLive 介绍
作为一款开源的 Redis 图形化监控工具,RedisLive 提供对 Redis 实例的内存使用情况,接收的客户端命令,接收的请求数量以及键进行监控.RedisLive 的工作原理基于 Redis ...
- Nginx+Tomcat+Redis实现持久会话
使用开源web应用solo blog进行项目演示.前端使用Nginx作为负载均衡器,后端Tomcat连接Redis实现session存储.Redis的特点就是可以将session持久化.样才能真正实现 ...
- ELK 快速指南
ELK 快速指南 概念 ELK 是什么 ELK 是 elastic 公司旗下三款产品 ElasticSearch .Logstash .Kibana 的首字母组合. ElasticSearch 是一个 ...
- A:点排序-poj
A:点排序 总时间限制: 1000ms 内存限制: 65536kB 描述 给定一个点的坐标(x, y),在输入的n个点中,依次计算这些点到指定点的距离,并按照距离进行从小到大排序,并且输出点的坐标 ...
- IOS 修改UIImage大小
在iOS中,uiimage没有用于修改大小的属性,要在代码中改变uiimage图片的大小,需要扩展UIImage类,如下: 头文件: #import<UIKit/UIKit.h> @int ...
- 安装 Qt 及所需 gcc 等
嫌麻烦,下载离线安装包一次性装好 Qt 及 Qt Creator (Community) Qt 安装包下载地址 http://download.qt.io/official_releases/qt/ ...
- gcc & gdb & make 定义与区别
GCC 通常所说的GCC是GUN Compiler Collection的简称,除了编译程序之外,它还含其他相关工具,所以它能把易于人类使用的高级语言编写的源代码构建成计算机能够直接执行的二进制代码. ...
- Tomcat 日志分割
一.前言 随着每天业务的增长,Tomcat 的catalina.out日志 变得越来越大,占用磁盘空间不说.要查看某个时候的日志的时候,庞大的日志让你顿时无从下手,所以日志的切割的变得刻不容缓.而且, ...