0

0

第十五章 MySQL 数据库_PHP教程

php中文网

php中文网

发布时间:2016-07-13 10:32:00

|

1288人浏览过

|

来源于php中文网

原创

学习要点:
1.Web 数据库概述
2.MySQL 的操作
3.MySQL 常用函数
4.SQL 语句详解
5.phpMyadmin

 

一.Web数据库概述

  现在,我们已经熟悉了PHP 的基础知识,这是我们想暂时离开PHP 一章,来重点介绍
一下关系型数据库,让大家了解数据库比文件储存的有点。这些优点包括:
1.关系型数据库比普通文件的数据访问速度更快。
2.关系型数据库更容易查阅并提取满足特定条件的数据。
3.关系型数据库更具有专门的内置机制处理并发访问,作为程序员,不需要为此担心。
4.关系型数据库可以提供对数据的随即访问。
5.关系型数据库具有内置的权限系统。

立即学习PHP免费学习笔记(深入)”;

 

关系数据库的概念
  至今为止,关系数据库是最常用的数据库类型。在关系代数方面,它们具有很好的理论
基础。当使用关系数据库的时候,并不需要了解关系理论(这是一件好事),但是还是需要
理解一些关于数据库的基本概念。

1)表格
  关系数据库由关系组成,这些关系通常称为表格。顾名思义,一个关系就是一个数据的
表格。电子数据表就是一种表格。

2)列
  表中的每一列都有惟一的名称,包含不同的数据。此外,每一列都有一个相关的数据类
型。
3)行
  表中的每一行代表一个客户。每一行具有相同的格式,因而也具有相同的属性。行也成
为记录。
4)值

  每一行由对应每一列的单个值组成。每个值必须与该列定义的数据类型相同。
5)键
  每一条数据所对应的唯一的标识。
6)模式
  数据库整套表格的完整设计成为数据库的模式。
7)关系
  外键标识两个表格数据的关系。
  如何设计Web 数据库
  1)考虑要建模的实际对象。
  2)避免保存冗余数据。
  3)使用原子列值(对每一行的每个属性只存储一个数据。)
  4)选择有意义的键。
  5)考虑需要询问数据库的问题。
  6)避免多个空属性的设计


Web 数据库架构
浏览器和Web 服务器之间的通信:

浏览器和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操作

登录到MySQL
1)打开MySQL Command Line Client
2)输入root 的设置密码

MySQL 常规命令

1)显示当前数据库的版本号和日期。
  SELECT VERSION(),CURRENT_DATE();
2)通过AS 关键字设置字段名。
  SELECT VERSION() AS version; //可设置中文,通过单引号
3)通过SELECT 执行返回计算结果
  SELECT (20+5)*4;
4)通过多行实现数据库的使用者和日期
  >SELECT
  >USER()
  >,
  >NOW()
  >;
5)通过一行显示数据库使用者和日期
  >SELECT USER();SELECT NOW();
6)命令的取消
  >\c
7)MySQL 窗口的退出
  >exit;

 

MySQL 常用数据类型

整数型:TINYINT,SMALLINT,INT,BIGINT
浮点型:FLOAT,DOUBLE,DECIMAL(M,D)
字符型:CHAR,VARCHAR
日期型:DATETIME,DATE,TIMESTAMP
备注型:TINYTEXT,TEXT,LONGTEXT

 

MySQL 数据库操作
1)显示当前存在的数据库
  >SHOW DATABASES;
2)选择你所需要的数据库
  >USE guest;
3)查看当前所选择的数据库
  >SELECT DATABASE();
4)查看一张表的所有内容
  >SELECT * FROM guest; //可以先通过SHOW TABLES;来查看有多少张表
5)根据数据库设置中文编码
  >SET NAMES gbk; //set names utf8;
6)创建一个数据库

  >CREATE DATABASE book;
7)在数据库里创建一张表
  >CREATE TABLE users (
  >username VARCHAR(20), //NOT NULL 设置不允许为空
  >sex CHAR(1),
  >birth DATETIME);
8)显示表的结构
  >DESCIRBE users;
9)给表插入一条数据
  >INSERT INTO users (username,sex,birth) VALUES ('Lee','x',NOW());
10)筛选指定的数据
  > SELECT * FROM users WHERE username = 'Lee';
11)修改指定的数据
  >UPDATE users SET sex = '男' WHERE username='Lee';
12)删除指定的数据
  > DELETE FROM users WHERE username='Lee';
13)按指定的数据排序
  > SELECT * FROM users ORDER BY birth DESC; //正序
14)删除指定的表
  >DROP TABLE users;
15)删除指定的数据库
  >DROP DATABASE book;

 

三.MySQL常用函数

初阶PHP Apache MySQL网站设计
初阶PHP Apache MySQL网站设计

初阶PHP Apache MySQL网站设计来自作者多年学习、应用和讲授PHP的经验与体会,是专为学习PHP+MySQL数据库编程人员编与的入门教材。在最后二章设计了2个贴近实际应用的典型案例:留言本系统和论坛系统,每个案例先介绍开发思路、步骤,再给出全部源代码,使所学内容与实际应用紧密结合,特别是论坛系统将全书的案例串讲起来,力求使读者学到最贴近应用前沿的知识和技能。

下载

 

四.SQL语句详解

1.创建一个班级数据库school,里面包含一张班级表grade,包含编号(id)、姓名(name)、
邮件(email)、评分(point)、注册日期(regdate)。
mysql>CREATE DATABASE school; //创建一个数据库
mysql> CREATE TABLE grade (
  //UNSIGNED 表示无符号,TINYINT(2) 无符号整数0-99,NOT NULL 表示不能为
空,AUTO_INCREMENT 表示从1 开始没增加一个字段,累计一位
  -> id TINYINT(2) UNSIGNED NOT NULL AUTO_INCREMENT,
  -> name VARCHAR(20) NOT NULL,
  -> email VARCHAR(40),
  -> point TINYINT(3) UNSIGNED NOT NULL,
  -> regdate DATETIME NOT NULL,
  -> PRIMARY KEY (id) //表示id 为主键,让id 值唯一,不得重复。
  -> );

2.给这个班级表grade 新增5-10 条学员记录
mysql> INSERT INTO grade (name,email,point,regdate) VALUES
('Lee','yc60.com@gmail.com',95,NOW());

3.查看班级所有字段的记录,查看班级id,name,email 的记录
mysql> SELECT * FROM grade;

mysql> SELECT id,name,email FROM grade;

4.姓名等于'Lee'的学员,成绩大于90 分的学员,邮件不为空的成员,70-90 之间的成员
  mysql> SELECT * FROM grade WHERE name='Lee';
  mysql> SELECT * FROM grade WHERE point>90;
  mysql> SELECT * FROM grade WHERE email IS NOT NULL;
  mysql> SELECT * FROM grade WHERE point BETWEEN 70 AND 90;
  mysql> SELECT * FROM grade WHERE point IN (95,82,78);
5.查找邮件使用163 的学员,不包含yc60.com 字符串的学员
  mysql> SELECT * FROM grade WHERE email LIKE '%163.com';
  mysql> SELECT * FROM grade WHERE email NOT LIKE '%yc60.com%';
6.按照学员注册日期的倒序排序,按照分数的正序排序
  mysql> SELECT * FROM grade ORDER BY regdate DESC;
  mysql> SELECT * FROM grade ORDER BY point ASC;
7.只显示前三条学员的数据,从第3 条数据开始显示2 条
  mysql> SELECT * FROM grade LIMIT 3;
  mysql> SELECT * FROM grade LIMIT 2,2;
8.修改姓名为'Lee'的电子邮件
  mysql> UPDATE grade SET email='yc60.com@163.com' WHERE name='Lee';

9.删除编号为4 的学员数据
  mysql> DELETE FROM grade WHERE id=4;

 

10.过一遍以上的分组函数
    略。
11.检查这个表的信息
  mysql> SHOW TABLE STATUS \G;
12.优化一张表
  mysql> OPTIMIZE TABLE grade;

 

五.PhpMyAdmin

phpMyAdmin(简称PMA)是一个用PHP 编写的,可以通过互联网在线控制和操作
MySQL。他是众多MySQL 管理员和网站管理员的首选数据库维护工具,通过phpMyAdmin
可以完全对MySQL 数据库进行操作。


创建数据库scholl
创建一个数据库->选择utf8 字符集


导出另一个数据库SQL
1.选择另一个数据库->导出
2.选择需要导出的表->全选
3.选择Add DROP TABLE / DROP VIEW (基本表一旦删除,表中的数据以及相应建立
的索引和视图都将自动被删除)
4.选择另存为文件
5.选择执行,保存sql 文件


导入数据库
1.选择被导入的数据库
2.选择Import(导入),选择sql 文件

3.执行即可

 

 

重建表
1.找到sql 文件中的刚才输出的建表语句.
2.复制建表语句
3.然后选择sql,选择粘贴,执行即可


修复数据表
1.选择要修复的表
2.在选中项中,选择修复表,即可


优化数据表
1.选择要优化的表
2.在选中项中,选择优化表,即可


修改,删除,插入表记录

执行SQL 语句

 

 注:文章出自李炎恢PHP视频教程,本文仅限交流使用,不得用于商业用途,否则后果自负。

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/759624.htmlTechArticle学习要点: 1.Web 数据库概述 2.MySQL 的操作 3.MySQL 常用函数 4.SQL 语句详解 5.phpMyadmin 一.Web数据库概述 现在,我们已经熟悉了PHP 的基础知识...

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

0

2026.02.28

Golang 工程化架构设计:可维护与可演进系统构建
Golang 工程化架构设计:可维护与可演进系统构建

Go语言工程化架构设计专注于构建高可维护性、可演进的企业级系统。本专题深入探讨Go项目的目录结构设计、模块划分、依赖管理等核心架构原则,涵盖微服务架构、领域驱动设计(DDD)在Go中的实践应用。通过实战案例解析接口抽象、错误处理、配置管理、日志监控等关键工程化技术,帮助开发者掌握构建稳定、可扩展Go应用的最佳实践方法。

2

2026.02.28

Golang 性能分析与运行时机制:构建高性能程序
Golang 性能分析与运行时机制:构建高性能程序

Go语言以其高效的并发模型和优异的性能表现广泛应用于高并发、高性能场景。其运行时机制包括 Goroutine 调度、内存管理、垃圾回收等方面,深入理解这些机制有助于编写更高效稳定的程序。本专题将系统讲解 Golang 的性能分析工具使用、常见性能瓶颈定位及优化策略,并结合实际案例剖析 Go 程序的运行时行为,帮助开发者掌握构建高性能应用的关键技能。

4

2026.02.28

Golang 并发编程模型与工程实践:从语言特性到系统性能
Golang 并发编程模型与工程实践:从语言特性到系统性能

本专题系统讲解 Golang 并发编程模型,从语言级特性出发,深入理解 goroutine、channel 与调度机制。结合工程实践,分析并发设计模式、性能瓶颈与资源控制策略,帮助将并发能力有效转化为稳定、可扩展的系统性能优势。

14

2026.02.27

Golang 高级特性与最佳实践:提升代码艺术
Golang 高级特性与最佳实践:提升代码艺术

本专题深入剖析 Golang 的高级特性与工程级最佳实践,涵盖并发模型、内存管理、接口设计与错误处理策略。通过真实场景与代码对比,引导从“可运行”走向“高质量”,帮助构建高性能、可扩展、易维护的优雅 Go 代码体系。

16

2026.02.27

Golang 测试与调试专题:确保代码可靠性
Golang 测试与调试专题:确保代码可靠性

本专题聚焦 Golang 的测试与调试体系,系统讲解单元测试、表驱动测试、基准测试与覆盖率分析方法,并深入剖析调试工具与常见问题定位思路。通过实践示例,引导建立可验证、可回归的工程习惯,从而持续提升代码可靠性与可维护性。

2

2026.02.27

漫蛙app官网链接入口
漫蛙app官网链接入口

漫蛙App官网提供多条稳定入口,包括 https://manwa.me、https

102

2026.02.27

deepseek在线提问
deepseek在线提问

本合集汇总了DeepSeek在线提问技巧与免登录使用入口,助你快速上手AI对话、写作、分析等功能。阅读专题下面的文章了解更多详细内容。

7

2026.02.27

AO3官网直接进入
AO3官网直接进入

AO3官网最新入口合集,汇总2026年可用官方及镜像链接,助你快速稳定访问Archive of Our Own平台。阅读专题下面的文章了解更多详细内容。

192

2026.02.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 路由精讲视频教程
React 路由精讲视频教程

共10课时 | 2.3万人学习

最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Rust 教程
Rust 教程

共28课时 | 6.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号