Mac环境下php操作mysql数据库的方法分享


Posted in PHP onMay 11, 2015

Mac本地环境搭建

在Mac系统,我们可以使用MAMP Pro 软件来搭建本地服务器。安装好这款软件,网站的目录在 /Applications/MAMP/htdocs 文件夹里,只需将文件放入该文件夹中,就可以通过http://localhost:8888来访问了,或者通过点击如下红色下划线按钮来快速访问站点。

Mac环境下php操作mysql数据库的方法分享

mac系统下安装php,两行即可。

brew tap josegonzalez/homebrew-php
brew install php54

安装完后配置一下,你就可以使用phpstorm来愉快地编程啦。安装的php路径在/usr/local/bin/php

数据库基本操作

Mac环境下php操作mysql数据库的方法分享

1)用户的 Web 浏览器发出 HTTP 请求,请求特定 Web 页面。
2)Web服务器收到.php 的请求获取该文件,并将它传到 PHP 引擎,要求它处理。 3)PHP 引擎开始解析脚本。 脚本中有一条连接数据库的命令, 还有执行一个查询的令。命
PHP 打开通向 MYSQL 数据库的连接,发送适当的查询。
4)MYSQL 服务器接收数据库查询并处理。将结果返回到 PHP 引擎。
5)PHP 以你去哪干完成脚本运行,通常,这包括将查询结果格式化成 HTML 格式。然
后再输出 HTML 返回到 Web 服务器。
6)Web服务器将 HTML 发送到浏览器。
MySQL 常用数据类型

整数型:TINYINT,SMALLINT,INT,BIGINT
浮点型:FLOA T,DOUB LE,DECIMAL(M,D)
字符型:CHAR,VARCHAR
日期型:DA TETIME,DA TE,TIMESTA MP
备注型:TINYTEXT,TEXT,LONGTEXT
MySQL 数据库操作

1)显示当前存在的数据库
    >SHOWDATABASES;
2)选择你所需要的数据库
    >USEguest;
3)查看当前所选择的数据库
    >SELECTDATABASE();
4)查看一张表的所有内容
    >SELECT*FROMguest; //可以先通过SHOWTABLES;来查看有多少张表
5)根据数据库设置中文编码
    >SET NAMESgbk; //set names utf8;
6)创建一个数据库
    >CREATEDATABASEbook;
7)在数据库里创建一张表
    >CREATETABLEusers (
    >username VARCHAR(20),//NOT NULL 设置不允许为空
    >sex CHAR(1),
    >birth DATETIME);
8)显示表的结构
    >DESCIRBEusers;

9)给表插入一条数据
   

>INSERT INTO users (username,sex,birth) VALUES('jack','male',NOW());

PHP连接MySQL数据库

连接数据库

<?php
  header('COntent-Type:text/html;charset=utf-8');//设置页面编码,如果文件是gbk编码,则charset也应用gbk
  //@表示如果出错了,不要报错,直接忽略
  //参数:服务器地址,用户名和密码

  echo (!!@mysql_connect('localhost','root','*****'));//1
?>

我们用双感叹号!!来将资源句柄转换成布尔值,正确输出1,错误则输出错误信息。而如果前面加了@符号,则忽略错误信息,不会输出错误信息。

对于错误消息的处理,我们可以使用mysql_error()函数来输出错误消息:

mysql_connect('localhost','root','****') or die('数据库连接失败,错误信息:'.mysql_error());//对于密码错误的提示:数据库连接失败,错误信息:Access denied for user 'root'@'localhost' (using password: YES)
die() 函数输出一条消息,并退出当前脚本。该函数是 exit() 函数的别名。

数据库连接参数,可以用常量来存储,这样就不能被随意修改,更加安全。

<meta charset="utf-8">
<?php
  //定义常量参数
  define('DB_HOST','localhost');
  define('DB_USER','root');
  define('DB_PWD','345823');//密码
  $connect = mysql_connect(DB_HOST,DB_USER,DB_PWD) or die('数据库连接失败,错误信息:'.mysql_error());
  echo $connect;//Resource id #2 
?>

值得注意的是,mysql_connect()括号内的常量可不能加引号,否则肯定出错。

选择指定的数据库

<?php
  define('DB_HOST','localhost');
  define('DB_USER','root');
  define('DB_PWD','345823');//密码
  define('DB_NAME','trigkit');//在phpmyadmin创建一个名为trigkit的数据库
  //连接数据库
  $connect = mysql_connect(DB_HOST,DB_USER,DB_PWD) or die('数据库连接失败,错误信息:'.mysql_error());
  //选择指定数据库
  mysql_select_db(DB_NAME,$connect) or die('数据库连接错误,错误信息:'.mysql_error());//将表名字故意写错,提示的错误信息:数据库连接错误,错误信息:Unknown database 'trigkt'
?>

通常不需要使用 mysql_close(),因为已打开的非持久连接会在脚本执行完毕后自动关闭

mysql_select_db(database,connection):选择MySQL数据库

获取记录集

<meta charset="utf-8">
<?php
  define('DB_HOST','localhost');
  define('DB_USER','root');
  define('DB_PWD','345823');//密码
  define('DB_NAME','trigkit');
  //连接数据库
  $connect = mysql_connect(DB_HOST,DB_USER,DB_PWD) or die('数据库连接失败,错误信息:'.mysql_error());
  //选择指定数据库
  mysql_select_db(DB_NAME,$connect) or die('数据表连接错误,错误信息:'.mysql_error());
  //从数据库里把表的数据提出来(获取记录集)
  $query = "SELECT * FROM class";//在trigkit数据库中新建一张'表'
  $result = mysql_query($query) or die('SQL错误,错误信息:'.mysql_error());//故意将表名写错:SQL错误,错误信息:Table 'trigkit.clas' doesn't exist
?>

mysql_query() 函数执行一条 MySQL 查询。

输出数据

<meta charset="utf-8">
<?php
  define('DB_HOST','localhost');
  define('DB_USER','root');
  define('DB_PWD','345823');//密码
  define('DB_NAME','trigkit');
  //连接数据库
  $connect = mysql_connect(DB_HOST,DB_USER,DB_PWD) or die('数据库连接失败,错误信息:'.mysql_error());
  //选择指定数据库,设置字符集
  mysql_select_db(DB_NAME,$connect) or die('数据表连接错误,错误信息:'.mysql_error());
  mysql_query('SET NAMES UTF8') or die('字符集设置出错'.mysql_error());
  //从数据库里把表的数据提出来(获取记录集)
  $query = "SELECT * FROM class";
  $result = mysql_query($query) or die('SQL错误,错误信息:'.mysql_error());
  print_r(mysql_fetch_array($result,MYSQL_ASSOC));
?>

释放结果集资源(仅需要在考虑到返回很大的结果集时会占用多少内存时调用。)

<?php
  mysql_free_result($result); 
?>

增删改查

新增数据

<?php
  require 'index.php';
  //新增数据
  $query = "INSERT INTO CLASS(
       name,
       email,
       point,
       regdate)
    VALUES (
    '小明',
    'xiaoming@163.com',
    100,
    NOW()
    )";

  @mysql_query($query) or die('新增错误:'.mysql_error());

?>

我们将上面的代码保存为index.php,丢进/Applications/MAMP/htdocs/ 文件夹。将上面的代码保存为demo.php,放进同样的目录内。Mac系统获取文件的路径很简单,只需将文件拉进终端即可显示路径名。

修改数据

我们假设要修改的数据的名称是小明,id为2,将他的point分数修改为80分,代码如下:

<?php
  require 'index.php';

  //修改数据
  $query = 'UPDATE class SET point=80 WHERE id=2';
  @mysql_query($query);
?>

删除数据

<?php
  require 'index.php';

  //删除数据
  $query = "DELETE FROM class WHERE id=2";
  @mysql_query($query);

  mysql_close();
?>

显示数据

<?php
  require 'index.php';

  //显示数据
  $query = "SELECT id,name,email,regdate FROM class";
  $result = mysql_query($query) or die('sql语句错误:'.mysql_error());

  print_r(mysql_fetch_array($result));
  mysql_close();
?>

或者显示指定值数据:

$data = mysql_fetch_array($result);
echo $data['email'];//显示email
echo $data['name'];//显示name

其他常用函数

mysql_fetch_lengths(): 取得结果集中每个输出的长度 

mysql_field_name(): 取得结果中指定字段的字段名
mysql _fetch_row():从结果集中取得一行作为枚举数组

mysql_fetch_assoc(): 从结果集中取得一行作为关联数组

mysql_fetch_array(): 从结果集中取得一行作为关联数组,或数字数组,或二者兼有
mysql_num_rows(): 取得结果集中行的数目 

mysql_num_fields():取得结果集中字段的数目
mysql_get_client_info(): 取得 MySQL 客户端信息 

mysql_get_host_info(): 取得 MySQL 主机信息 

mysql_get_proto_info(): 取得 MySQL 协议信息 

mysql_get_server_info(): 取得 MySQL 服务器信息

以上所述就是本文的全部内容了,希望大家能够喜欢。

PHP 相关文章推荐
php 获取本机外网/公网IP的代码
May 09 PHP
php引用地址改变变量值的问题
Mar 23 PHP
解析php中用PHPMailer来发送邮件的示例(126.com的例子)
Jun 24 PHP
两级联动select刷新后其值保持不变的实现方法
Jan 27 PHP
PHP获取短链接跳转后的真实地址和响应头信息的方法
Jul 25 PHP
php中cookie实现二级域名可访问操作的方法
Nov 11 PHP
PHP实现动态web服务器方法
Jul 29 PHP
PHP中使用substr()截取字符串出现中文乱码问题该怎么办
Oct 21 PHP
php+ajax无刷新上传图片实例代码
Nov 17 PHP
PHP创建单例后台进程的方法示例
May 23 PHP
PHP闭包定义与使用简单示例
Apr 13 PHP
PHP根据key删除数组中指定的元素
Feb 28 PHP
PHP设计模式之装饰者模式代码实例
May 11 #PHP
PHP超牛逼无限极分类生成树方法
May 11 #PHP
php以fastCGI的方式运行时文件系统权限问题及解决方法
May 11 #PHP
PHP获取当前日期和时间及格式化方法参数
May 11 #PHP
PHP借助phpmailer发送邮件
May 11 #PHP
PHP date函数常用时间处理方法
May 11 #PHP
护卫神php套件 php版本升级方法(php5.5.24)
May 10 #PHP
You might like
MySQL中create table语句的基本语法是
2007/01/15 PHP
关于url地址传参数时字符串有回车造成页面脚本赋值失败的解决方法
2013/06/28 PHP
PHP实现图片防盗链破解操作示例【解决图片防盗链问题/反向代理】
2020/05/29 PHP
javascript学习笔记(十五) js间歇调用和超时调用
2012/06/20 Javascript
js如何判断不同系统的浏览器类型
2013/10/28 Javascript
JavaScript判断用户是否对表单进行了修改的方法
2015/03/18 Javascript
你一定会收藏的Nodejs代码片段
2016/02/04 NodeJs
简单实现jQuery进度条轮播实例代码
2016/06/20 Javascript
深入浅析JS Function()构造函数
2016/08/22 Javascript
JavaScript实现简易的天数计算器实例【附demo源码下载】
2017/01/18 Javascript
js实现网页版贪吃蛇游戏
2020/02/22 Javascript
Vue+ElementUI 中级联选择器Bug问题的解决
2020/07/31 Javascript
Javascript call及apply应用场景及实例
2020/08/26 Javascript
微信小程序基于高德地图API实现天气组件(动态效果)
2020/10/22 Javascript
[01:02:00]DOTA2-DPC中国联赛 正赛 Elephant vs IG BO3 第三场 1月24日
2021/03/11 DOTA
深入浅析Python中join 和 split详解(推荐)
2016/06/30 Python
全面了解python中的类,对象,方法,属性
2016/09/11 Python
Python新手们容易犯的几个错误总结
2017/04/01 Python
在Python中执行系统命令的方法示例详解
2017/09/14 Python
Python获取二维矩阵每列最大值的方法
2018/04/03 Python
对pandas中iloc,loc取数据差别及按条件取值的方法详解
2018/11/06 Python
Python实现的微信红包提醒功能示例
2019/08/22 Python
python实现logistic分类算法代码
2020/02/28 Python
Python基于codecs模块实现文件读写案例解析
2020/05/11 Python
Python编写万花尺图案实例
2021/01/03 Python
详解H5 活动页之移动端 REM 布局适配方法
2017/12/07 HTML / CSS
美国男士内衣品牌:Tommy John
2017/12/22 全球购物
Rossignol金鸡美国官网:始于1907年法国百年雪具品牌
2019/03/06 全球购物
linux面试题参考答案(2)
2015/12/06 面试题
质检员的岗位职责
2013/11/15 职场文书
高校教师岗位职责
2014/03/18 职场文书
投资建议书模板
2014/05/12 职场文书
会计个人实习计划书
2014/08/15 职场文书
办理信用卡收入证明范例
2014/09/13 职场文书
2019各种承诺书范文
2019/06/24 职场文书
一文搞清楚MySQL count(*)、count(1)、count(col)区别
2022/03/03 MySQL