您的位置:

mysql数据库第7章(数据库第七章)

本文目录一览:

求php+MYSQL入门到精通的视频教程,教材也可以!急急急!

电骡上的资源:

课程介绍:

1. 从观念的引述、程序代码解析到范例的延伸应用,给您最完整的学习流程。

2. 实务网站范例,所有技术整合运用,实作技巧一览无遗。

3.在PHP的程序设计中,以高阶的程序设计,配上灵活的图解,增加您程序设计的功力,也能够了解其演算的过程。

4.MySQL数据库设计方面,使用数据库的正规化的方法解决了数据表的分割,来建立关系型数据库,使您有系统的处理现实生活的程序设计。

5. 深入对象导向程序设计,全新视界与技巧,网页开发更得心应手。

6.课程中提供范例教您设计实用的PHPMySQL数据库,包含加入会员与密码验证、聊天室、留言版、讨论区…等。

7.本课程提供一个网上购物系统实例,根据本实例让你更多的了解PHPMYSQL在商业网站设计中所提供的强大功能,以及如何才能设计出此类站点。

8.在实战方面,演示了目前功能最强大的ORACLE 9i for linux最新版9.2.0.4在Linux下的安装及PHP与Oracle数据库之间的连接。

9.在热点研究篇里面,列举了目前最热门的PHP技术,让你在学习的同时掌握到目前最新的PHP技术。

老师介绍:

徐文龙 -- 系统架构师/系统分析师/高级培训讲师,拥有多年软件及数据库开发经验,擅长面向对象的设计和分析、数据库建模以及软件开发方法,精通.NET、J2EE、C++、PHP、Oracle/SQL SERVER/Informix/DB2 数据库等,对各主流数据库拥有强大的设计与实现能力,对性能调优有深入的体会和经验,对OOA、OOD、设计模式、UML有深入的理解。已经获得 OCP,SCJP,MCDBA,MCSE,MCP,TLCE等证书,主讲ORACLE9i、SQL Server、 J2EE、.NET、Linux、DB2, 成功授课案例有深圳市国税局、深圳市福田公路局、香港国兴集团、深圳市邮政局、中国农行深圳分行、深圳市地税局、招商银行、平安保险、广东核电技术中心、蛇口ST码头等等。

课程安排 :

I 理论篇

第一章 了解PHP(起源,特性,与ASP/ASP.NET和JAVA比较,PHP环境部署,IDE)

第二章 PHP语法结构

第三章 PHP函数库

第四章 了解MySQL

第五章 MySQL语言结构

第六章 MySQL数据类型

第七章 MySQL函数

第八章 MySQL数据操纵语言DML

第九章 MySQL数据定义语言DDL

第十章 MySQL用户实用命令

第十一章 MySQL 事务与锁定

第十二章 MySQL 全文检索

第十三章 MySQL 查询缓存

第十四章 MySQL数据库管理

SQL Server 2000 Job实现、警报实现、真实应用最佳实践。

II 实战篇 ―― 小试牛刀

第十五章 计数器

第十六章 以PHP实现文件上载

第十七章 时钟

第十八章 日历

第十九章 地址簿

第二十章 图像处理

第二十一章 表单处理

第二十二章 发邮件

第二十三章 数据库操作

第十章:SQL Server 2000的复制体系

第二十四章 Oracle数据库连接

III实战篇 ―― 高级应用

第二十五章 留言本

第二十六章 留言本(Oracle)

第二十七章 在线投票系统

第二十八章 论坛

第二十九章 聊天室

第三十章 网上购物系统

第三十一章 新闻系统

超详细MySQL数据库优化

数据库优化一方面是找出系统的瓶颈,提高MySQL数据库的整体性能,而另一方面需要合理的结构设计和参数调整,以提高用户的相应速度,同时还要尽可能的节约系统资源,以便让系统提供更大的负荷.

1. 优化一览图

2. 优化

笔者将优化分为了两大类,软优化和硬优化,软优化一般是操作数据库即可,而硬优化则是操作服务器硬件及参数设置.

2.1 软优化

2.1.1 查询语句优化

1.首先我们可以用EXPLAIN或DESCRIBE(简写:DESC)命令分析一条查询语句的执行信息.

2.例:

显示:

其中会显示索引和查询数据读取数据条数等信息.

2.1.2 优化子查询

在MySQL中,尽量使用JOIN来代替子查询.因为子查询需要嵌套查询,嵌套查询时会建立一张临时表,临时表的建立和删除都会有较大的系统开销,而连接查询不会创建临时表,因此效率比嵌套子查询高.

2.1.3 使用索引

索引是提高数据库查询速度最重要的方法之一,关于索引可以参高笔者MySQL数据库索引一文,介绍比较详细,此处记录使用索引的三大注意事项:

2.1.4 分解表

对于字段较多的表,如果某些字段使用频率较低,此时应当,将其分离出来从而形成新的表,

2.1.5 中间表

对于将大量连接查询的表可以创建中间表,从而减少在查询时造成的连接耗时.

2.1.6 增加冗余字段

类似于创建中间表,增加冗余也是为了减少连接查询.

2.1.7 分析表,,检查表,优化表

分析表主要是分析表中关键字的分布,检查表主要是检查表中是否存在错误,优化表主要是消除删除或更新造成的表空间浪费.

1. 分析表: 使用 ANALYZE 关键字,如ANALYZE TABLE user;

2. 检查表: 使用 CHECK关键字,如CHECK TABLE user [option]

option 只对MyISAM有效,共五个参数值:

3. 优化表:使用OPTIMIZE关键字,如OPTIMIZE [LOCAL|NO_WRITE_TO_BINLOG] TABLE user;

LOCAL|NO_WRITE_TO_BINLOG都是表示不写入日志.,优化表只对VARCHAR,BLOB和TEXT有效,通过OPTIMIZE TABLE语句可以消除文件碎片,在执行过程中会加上只读锁.

2.2 硬优化

2.2.1 硬件三件套

1.配置多核心和频率高的cpu,多核心可以执行多个线程.

2.配置大内存,提高内存,即可提高缓存区容量,因此能减少磁盘I/O时间,从而提高响应速度.

3.配置高速磁盘或合理分布磁盘:高速磁盘提高I/O,分布磁盘能提高并行操作的能力.

2.2.2 优化数据库参数

优化数据库参数可以提高资源利用率,从而提高MySQL服务器性能.MySQL服务的配置参数都在my.cnf或my.ini,下面列出性能影响较大的几个参数.

2.2.3 分库分表

因为数据库压力过大,首先一个问题就是高峰期系统性能可能会降低,因为数据库负载过高对性能会有影响。另外一个,压力过大把你的数据库给搞挂了怎么办?所以此时你必须得对系统做分库分表 + 读写分离,也就是把一个库拆分为多个库,部署在多个数据库服务上,这时作为主库承载写入请求。然后每个主库都挂载至少一个从库,由从库来承载读请求。

2.2.4 缓存集群

如果用户量越来越大,此时你可以不停的加机器,比如说系统层面不停加机器,就可以承载更高的并发请求。然后数据库层面如果写入并发越来越高,就扩容加数据库服务器,通过分库分表是可以支持扩容机器的,如果数据库层面的读并发越来越高,就扩容加更多的从库。但是这里有一个很大的问题:数据库其实本身不是用来承载高并发请求的,所以通常来说,数据库单机每秒承载的并发就在几千的数量级,而且数据库使用的机器都是比较高配置,比较昂贵的机器,成本很高。如果你就是简单的不停的加机器,其实是不对的。所以在高并发架构里通常都有缓存这个环节,缓存系统的设计就是为了承载高并发而生。所以单机承载的并发量都在每秒几万,甚至每秒数十万,对高并发的承载能力比数据库系统要高出一到两个数量级。所以你完全可以根据系统的业务特性,对那种写少读多的请求,引入缓存集群。具体来说,就是在写数据库的时候同时写一份数据到缓存集群里,然后用缓存集群来承载大部分的读请求。这样的话,通过缓存集群,就可以用更少的机器资源承载更高的并发。

一个完整而复杂的高并发系统架构中,一定会包含:各种复杂的自研基础架构系统。各种精妙的架构设计.因此一篇小文顶多具有抛砖引玉的效果,但是数据库优化的思想差不多就这些了.

数据库(mysql)关键知识

Mysql是目前互联网使用最广的关系数据库,关系数据库的本质是将问题分解为多个分类然后通过关系来查询。 一个经典的问题是用户借书,三张表,一个用户,一个书,一个借书的关系表。当需要查询某个用户借书情况或者是书被那些人借了,就用关系查询来实现。

关系数据库范式

来自英文Normal form,简称NF。要想设计—个好的关系,必须使关系满足一定的约束条件,满足这些规范的数据库是简洁的、结构明晰的,同时,不会发生插入(insert)、删除(delete)和更新(update)操作异常。总共有六种范式:第一范式(1NF)、第二范式(2NF)、 第三范式 (3NF)、巴斯-科德范式(BCNF)、 第四范式 (4NF)和 第五范式 (5NF,又称完美范式)。

1NF是指数据库表的每一列都是不可分割的原子数据项。2NF必须满足1NF,要求数据库表中的每行记录必须可以被唯一地区分。3NF在2NF基础上,任何非主 属性 不依赖于其它非主属性(在2NF基础上消除传递依赖)。BCNF是在3NF基础上,任何非主属性不能对主键子集依赖(在3NF基础上消除对主码子集的依赖), 满足BCNF不再会有任何由于函数依赖导致的异常,但是我们还可能会遇到由于多值依赖导致的异常。4NF的定义很简单:已经是BC范式,并且不包含多值依赖关系。5NF处理的是无损连接问题,这个范式基本没有实际意义,因为无损连接很少出现,而且难以察觉。而域键范式试图定义一个终极范式,该范式考虑所有的依赖和约束类型,但是实用价值也是最小的,只存在理论研究中。

Catalog和Schema

是数据库对象命名空间中的层次,主要用来解决命名冲突的问题。从概念上说,一个数据库系统包含多个Catalog,每个Catalog又包含多个Schema,而每个Schema又包含多个数据库对象(表、视图、字段等)。但是Mysql的数据库名就是Schema,不支持Catalog。

Mysql的数据库引擎主要有两种MyISAM和InnoDB,MyISAM支持全文检索,InnoDB支持事务。

SQL中的通配符‘%’代表任意字符出现任意次数。‘_’代表任意字符出现一次。SQL与正则表达式结合查询一般用在WHERE table_name REGEXP '^12.34'。子查询是从里到外执行。

数据库联结(join)涉及到外键,外键是指一个表的列是另一个表的主键,那么它就是外键。笛卡尔积联结(不指定联结条件时)生成的记录条目是单纯的第一个表的行乘以第二个表的列数。用得最多的是等值联结也叫内部联结。

高级联结还有自连接,是指查询中的两张表是同一张表,它通常作为外部语句用来代替从相同表中检索数据时使用的子查询。自然联结使每个列只返回一次。外部联结是指联结包含了那些在相关表中没有关联行的行。例如列出所有产品及其订购数量,包括没有人订购的产品。LEFT OUTER JOIN指选择左边表的所有行。

组合查询是指采用UNION等将两个查询结果取并集。

视图是查看存储在别处的数据的一种工具,它本身并不包含数据,因此表的数据修改了,视图返回的数据也将随之修改,因此如果使用了复杂或嵌套视图会对性能有较大的影响。视图的作用之一是隐藏复杂的SQL通常会涉及到联结查询。

存储过程类似于批处理,包含了一条或多条SQL语句。语法:

CREATE PROCEDURE name()

BEGIN

SQL

END

-------------------------

CALL name()//来调用存储过程

游标有DECLARE定义,游标与存储过程是绑定的,存储过程处理完成,游标就会消失。游标被打开后可以使用FETCH语句访问每一行。

触发器是在某个时间发生时自动执行某条SQL语句。语法:

CREATE TRIGGER name AFTER INSERT ON talbe_name FOR EACH ROW

事务处理可以维护数据库的完整性,保证批量的操作要么完全执行,要么完全不执行。包括事务、回退、提交、保留点几个关键术语。ROLLBACK只能在一个事务处理内使用。他不能回退CREATE和DROP操作。使用COMMIT保证事务提交。复杂的事务处理需要部分提交或回退,因此我们需要使用保留点SAVEPOINT。可以使用ROLLBACK TO savepoint_name。保留点越多越好。保留点在事务执行完成后自动释放。

扛得住的MySQL数据库架构

数据库优化是系统工程,性能的提升靠整体。本课程将面面俱到的讲解提升数据库性能的各种因素,让你在最短的时间从小白到资深,将数据库整体架构了然于胸

第1章 实例和故事 试看7 节 | 50分钟

决定电商11大促成败的各个关键因素。

收起列表

视频:1-1 什么决定了电商双11大促的成败 (04:04)试看

视频:1-2 在双11大促中的数据库服务器 (06:03)

视频:1-3 在大促中什么影响了数据库性能 (07:55)

视频:1-4 大表带来的问题 (14:13)

视频:1-5 大事务带来的问题 (17:27)

作业:1-6 【讨论题】在日常工作中如何应对高并发大数据量对数据库性能挑战

作业:1-7 【讨论题】在MySQL中事务的作用是什么?

第2章 什么影响了MySQL性能 试看30 节 | 210分钟

详细介绍影响性能各个因素,包括硬件、操作系统等等。

收起列表

视频:2-1 影响性能的几个方面 (04:08)试看

视频:2-2 CPU资源和可用内存大小 (10:54)

视频:2-3 磁盘的配置和选择 (04:44)

视频:2-4 使用RAID增加传统机器硬盘的性能 (11:30)

视频:2-5 使用固态存储SSD或PCIe卡 (08:35)

视频:2-6 使用网络存储SAN和NAS (07:16)

视频:2-7 总结:服务器硬件对性能的影响 (03:27)

视频:2-8 操作系统对性能的影响-MySQL适合的操作系统 (03:50)

视频:2-9 CentOS系统参数优化 (11:43)

视频:2-10 文件系统对性能的影响 (03:29)

视频:2-11 MySQL体系结构 (05:29)

视频:2-12 MySQL常用存储引擎之MyISAM (13:23)

视频:2-13 MySQL常用存储引擎之Innodb (10:44)

视频:2-14 Innodb存储引擎的特性(1) (15:24)

视频:2-15 Innodb存储引擎的特性(2) (08:44)

视频:2-16 MySQL常用存储引擎之CSV (09:19)

视频:2-17 MySQL常用存储引擎之Archive (06:08)

视频:2-18 MySQL常用存储引擎之Memory (10:40)

视频:2-19 MySQL常用存储引擎之Federated (11:21)

视频:2-20 如何选择存储引擎 (04:33)

视频:2-21 MySQL服务器参数介绍 (08:04)

视频:2-22 内存配置相关参数 (09:24)

视频:2-23 IO相关配置参数 (10:01)

视频:2-24 安全相关配置参数 (06:13)

视频:2-25 其它常用配置参数 (03:41)

视频:2-26 数据库设计对性能的影响 (04:36)

视频:2-27 总结 (01:32)

作业:2-28 【讨论题】你会如何配置公司的数据库服务器硬件?

作业:2-29 【讨论题】你认为对数据库性能影响最大的因素是什么

作业:2-30 【讨论题】做为电商的DBA,建议开发选哪种MySQL存储引擎

第3章 MySQL基准测试8 节 | 65分钟

了解基准测试,MySQL基准测试工具介绍及实例演示。

收起列表

视频:3-1 什么是基准测试 (02:20)

视频:3-2 如何进行基准测试 (09:00)

视频:3-3 基准测试演示实例 (11:18)

视频:3-4 Mysql基准测试工具之mysqlslap (13:30)

视频:3-5 Mysql基准测试工具之sysbench (11:07)

视频:3-6 sysbench基准测试演示实例 (17:11)

作业:3-7 【讨论题】MySQL基准测试是否可以体现出业务系统的真实性能

作业:3-8 【实操题】参数不同取值对性能的影响

第4章 MySQL数据库结构优化14 节 | 85分钟

详细介绍数据库结构设计、范式和反范式设计、物理设计等等。

收起列表

视频:4-1 数据库结构优化介绍 (06:52)

视频:4-2 数据库结构设计 (14:49)

视频:4-3 需求分析及逻辑设计 (11:00)

视频:4-4 需求分析及逻辑设计-反范式化设计 (06:44)

视频:4-5 范式化设计和反范式化设计优缺点 (04:06)

视频:4-6 物理设计介绍 (05:17)

视频:4-7 物理设计-数据类型的选择 (18:59)

视频:4-8 物理设计-如何存储日期类型 (13:37)

视频:4-9 物理设计-总结 (02:37)

图文:4-10 说明MyISAM和Innodb存储引擎的5点不同

作业:4-11 【讨论题】判断表结构是否符合第三范式要求?如不满足要如何修改

作业:4-12 【实操题】请设计一个电商订单系统的数据库结构

作业:4-13 【讨论题】以下那个字段适合作为Innodb表的主建使用

作业:4-14 【讨论题】请为下表中的字段选择合适的数据类型

第5章 MySQL高可用架构设计 试看24 节 | 249分钟

详细介绍二进制日志及其对复制的影响、GTID的复制、MMM、MHA等等。

收起列表

视频:5-1 mysql复制功能介绍 (04:58)

视频:5-2 mysql二进制日志 (22:05)

视频:5-3 mysql二进制日志格式对复制的影响 (09:37)

视频:5-4 mysql复制工作方式 (03:08)

视频:5-5 基于日志点的复制 (20:06)

视频:5-6 基于GTID的复制 (22:32)

视频:5-7 MySQL复制拓扑 (13:58)

视频:5-8 MySQL复制性能优化 (09:23)

视频:5-9 MySQL复制常见问题处理 (08:31)

视频:5-10 什么是高可用架构 (14:09)

视频:5-11 MMM架构介绍 (08:09)

视频:5-12 MMM架构实例演示(上) (09:16)试看

视频:5-13 MMM架构实例演示(下) (18:55)

视频:5-14 MMM架构的优缺点 (08:01)

视频:5-15 MHA架构介绍 (10:02)

视频:5-16 MHA架构实例演示(1) (13:11)

视频:5-17 MHA架构实例演示(2) (16:54)

视频:5-18 MHA架构优缺点 (05:14)

视频:5-19 读写分离和负载均衡介绍 (11:42)

视频:5-20 MaxScale实例演示 (18:25)

作业:5-21 【讨论题】MySQL主从复制为什么会有延迟,延迟又是如何产生

作业:5-22 【实操题】请为某互联网项目设计99.99%MySQL架构

作业:5-23 【讨论题】如何给一个已经存在的主从复制集群新增一个从节点

作业:5-24 【讨论题】给你三台数据库服务器,你如何设计它的高可用架构

第6章 数据库索引优化8 节 | 65分钟

介绍BTree索引和Hash索引,详细介绍索引的优化策略等等。

收起列表

视频:6-1 Btree索引和Hash索引 (20:09)

视频:6-2 安装演示数据库 (01:19)

视频:6-3 索引优化策略(上) (17:33)

视频:6-4 索引优化策略(中) (13:02)

视频:6-5 索引优化策略(下) (12:30)

作业:6-6 【讨论题】一列上建立了索引,查询时就一定会用到这个索引吗

作业:6-7 【讨论题】在定义联合索引时为什么需要注意联合索引中的顺序

作业:6-8 【实操题】SQL建立索引,你会考虑那些因素

第7章 SQL查询优化9 节 | 62分钟

详细介绍慢查询日志及示例演示,MySQL查询优化器介绍及特定SQL的查询优化等。

收起列表

视频:7-1 获取有性能问题SQL的三种方法 (05:14)

视频:7-2 慢查询日志介绍 (08:57)

视频:7-3 慢查询日志实例 (08:27)

视频:7-4 实时获取性能问题SQL (02:21)

视频:7-5 SQL的解析预处理及生成执行计划 (16:02)

视频:7-6 如何确定查询处理各个阶段所消耗的时间 (09:35)

视频:7-7 特定SQL的查询优化 (10:34)

作业:7-8 【讨论题】如何跟据需要对一个大表中的数据进行删除或更新

作业:7-9 【讨论题】如何获取需要优化的SQL查询

第8章 数据库的分库分表5 节 | 48分钟

详细介绍数据库分库分表的实现原理及演示案例等。

收起列表

视频:8-1 数据库分库分表的几种方式 (04:34)

视频:8-2 数据库分片前的准备 (13:53)

视频:8-3 数据库分片演示(上) (11:40)

视频:8-4 数据库分片演示(下) (17:02)

作业:8-5 【讨论题】对于大表来说我们一定要进行分库分表吗

第9章 数据库监控7 节 | 29分钟

介绍数据库可用性监控、性能监控、MySQL主从复制监控等

收起列表

视频:9-1 数据库监控介绍 (04:46)

视频:9-2 数据库可用性监控 (07:20)

视频:9-3 数据库性能监控 (09:39)

视频:9-4 MySQL主从复制监控 (06:16)

作业:9-5 【讨论题】QPS是否可以真实的反映出数据库的负载情况

作业:9-6 【讨论题】如何正确评估数据库的当前负载状况

作业:9-7 【实操题】开发一个简单监控脚本,监控mySQL数据库阻塞情况

MySQL必知必会 第7-9章

在第六章介绍的所有 WHERE 子句在过滤时,使用的都是单一的条件。为了进行更强的过滤控制,MySQL允许给出多个WHERE子句,并通过 AND 或 OR 操作符的方式组合使用。

AND 操作符可以使用对多列的条件进行累加过滤。

OR操作符可以使用对多列的条件进行累加过滤。

WHERE 子句可包含任意数目的 AND 和 OR 操作符。但是 AND 的优先级比 OR 高,应使用适当的圆括号分组操作符。

注意: 任何时候都不应该过分依赖默认计算次序,使用圆括号可以增加可读性,消除歧义。

IN 操作符用来指定条件范围,范围中每个条件都可以进行匹配。 IN 的合法值由逗号分隔,并全部括在圆括号中。

使用 IN 的优点为:

WHERE子句中的NOT操作符有且只有一个功能,就是否定它之后的任何条件。

注意: MySQL支持使用NOT对IN、BETWEEN和EXISTS子句取反,这与其他大多数DBMS允许使用NOT对各种条件取反有很大区别。

之前介绍的都是针对已知值的过滤。而对进行未知内容的匹配,可以使用通配符创建比较数据的搜索模式来完成。通配符的匹配,需要通过LIKE操作符指示MySQL完成。

% 表示任何字符出现任意次。例如,为了找到所有以 jet 起头的产品,可使用以下 SELECT 语句

注意:

下划线( _ )通配符只匹配单个字符而不是多个字符。

通配符使用技巧:

正则表达式是用来匹配文本的特殊串(字符集合),所有种类的程序设计语言、文本编辑器、操作系统等都支持正则表达式。

MySQL中的正则表达式仅是正则表达式的一个子集。

为搜索两个串之一,使用( | )。

如果想匹配特定的单一字符,可以使用[]将一组指定的内容括起来。

注意:

集合可用来定义要匹配一个或多个字符,此时可以使用 - 来定义一个范围,例如 [0-9] 表示数字0到9, [a-z] 表示字母a到z。

正则表达式语句由具有特定含义的特殊字符构成。例如 | 或 - 等。如果要表示一些特殊的字母,如含 . 的值,则应该使用 \\\ 为前导。 \\\- 表示查找 - , \\\. 表示查找 . 。

注意:

为方便常见字符集的查找,可以使用预定义的字符集。称为字符类。如下图所示:

目前为止使用的所有正则表达式都试图匹配单词出现。但有时需要对匹配的数目进行更强的控制,此时可以使用下列正则表达式重复元字符来完成。

注意: 使用正则表达式时,编写某个特定的表达式几乎总是有多种方法。

目前为止,所有例子都是匹配一个串中任意位置的文本,为了匹配特定位置的文本,需要使用定位符。

注意:

php和mysql web开发的目录

读者反馈

译者序

前言

作者简介

第一篇使用PHP

第1章PHP快速入门教程1

1.1开始之前:了解PHP

1.2创建一个示例应用:Bob汽车零部件商店2

1.2.1创建订单表单2

1.2.2表单处理4

1.3在HTML中嵌入PHP4

1.3.1使用PHP标记5

1.3.2PHP语句6

1.3.3空格6

1.3.4注释7

1.4添加动态内容8

1.4.1调用函数8

1.4.2使用date()函数9

1.5访问表单变量9

1.5.1简短、中等以及长风格的表单变量9

1.5.2字符串的连接11

1.5.3变量和文本12

1.6理解标识符13

1.7检查变量类型13

1.7.1PHP的数据类型

1.7.2类型强度

1.7.3类型转换

1.7.4可变变量

1.8声明和使用常量13

1.9理解变量的作用域13

1.10使用操作符16

1.10.1算术操作符17

1.10.2字符串操作符17

1.10.3赋值操作符17

1.10.4比较操作符19

1.10.5逻辑操作符20

1.10.6位操作符21

1.10.7其他操作符21

1.11计算表单总金额23

1.12理解操作符的优先级和结合性:

1.13使用可变函数25

1.13.1测试和设置变量类型26

1.13.2测试变量状态26

1.13.3变量的重解释27

1.14根据条件进行决策27

1.14.1if语句28

1.14.2代码块28

1.14.3else语句28

1.14.4elseif语句29

1.14.5switch语句30

1.14.6比较不同的条件31

1.15通过迭代实现重复动作32

1.15.1while循环33

1.15.2for和foreach循环34

1.15.3do...while循环35

1.16从控制结构或脚本中跳出35

1.17使用可替换的控制结构语法36

1.18使用declare36

1.19下一章37

第2章数据的存储与检索38

2.1保存数据以便后期使用38

2.2存储和检索Bob的订单38

2.3文件处理39

2.4打开文件40

2.4.1选择文件模式40

2.4.2使用fopen()打开文件40

2.4.3通过FTP或HTTP打开文件42

2.4.4解决打开文件时可能遇到的问题42

2.5写文件44

2.5.1fwrite()的参数44

2.5.2文件格式45

2.6关闭文件45

2.7读文件47

2.7.1以只读模式打开文件:fopen()48

2.7.2知道何时读完文件:feof()48

2.7.3每次读取一行数据:fgets()、fgetss()和fgetcsv()49

2.7.4读取整个文件:readfile()、fpassthru()和file()49

2.7.5读取一个字符:fgetc()50

2.7.6读取任意长度:fread()51

2.8使用其他有用的文件函数51

2.8.1查看文件是否存在:file_exists()51

2.8.2确定文件大小:filesize()51

2.8.3删除一个文件:unlink()51

2.8.4在文件中定位:rewind()、fseek()和ftell()52

2.9文件锁定52

2.10更好的方式:数据库管理系统53

2.10.1使用普通文件的几个问题54

2.10.2RDBMS是如何解决这些问题的54

2.11进一步学习54

2.12下一章55

第3章使用数组56

3.1什么是数组56

3.2数字索引数组57

3.2.1数字索引数组的初始化57

3.2.2访问数组的内容57

3.2.3使用循环访问数组58

3.3使用不同索引的数组59

3.3.1初始化相关数组59

3.3.2访问数组元素59

3.3.3使用循环语句59

3.4数组操作符60

3.5多维数组61

3.6数组排序64

3.6.1使用sort()函数64

3.6.2使用asort()函数和ksort()函数对相关数组排序64

3.6.3反向排序65

3.7多维数组的排序65

3.7.1用户定义排序65

3.7.2反向用户排序66

3.8对数组进行重新排序67

3.8.1使用shuffle()函数67

3.8.2使用array_reverse()函数68

3.9从文件载入数组69

3.10执行其他的数组操作71

3.10.1在数组中浏览:each()、current()、reset()、end()、next()、pos()和prev()71

3.10.2对数组的每一个元素应用任何函数:array_walk()72

3.10.3统计数组元素个数:count()、sizeof()和array_count_values()73

3.10.4将数组转换成标量变量:extract()73

3.11进一步学习75

3.12下一章75

第4章字符串操作与正则表达式76

4.1创建一个示例应用程序:智能表单邮件76

4.2字符串的格式化78

4.2.1字符串的整理:chop()、ltrim()和trim()78

4.2.2格式化字符串以便显示78

4.2.3格式化字符串以便存储:addslashes()和stripslashes()81

4.3用字符串函数连接和分割字符串82

4.3.1使用函数explode()、implode()和join()82

4.3.2使用strtok()函数83

4.3.3使用substr()函数83

4.4字符串的比较84

4.4.1字符串的排序:strcmp()、strcasecmp()和strnatcmp()84

4.4.2使用strlen()函数测试字符串的长度85

4.5使用字符串函数匹配和替换子字符串85

4.5.1在字符串中查找字符串:strstr()、strchr()、strrchr()和stristr()85

4.5.2查找子字符串的位置:strpos()、strrpos()86

4.5.3替换子字符串:str_replace()、substr_replace()87

4.6正则表达式的介绍88

4.6.1基础知识88

4.6.2字符集和类88

4.6.3重复89

4.6.4子表达式89

4.6.5子表达式计数90

4.6.6定位到字符串的开始或末尾90

4.6.7分支90

4.6.8匹配特殊字符90

4.6.9特殊字符一览91

4.6.10在智能表单中应用91

4.7用正则表达式查找子字符串92

4.8使用正则表达式分割字符串93

4.9比较字符串函数和正则表达式函数93

4.10进一步学习93

4.11下一章93

第5章代码重用与函数编写94

5.1代码重用的好处

5.1.1成本94

5.1.2可靠性94

5.1.3一致性95

5.2使用require()和include()函数95

5.2.1文件扩展名和require()语句96

5.2.2使用require()制作Web站点的模版96

5.2.3使用auto_prepend_file和auto_append_file101

5.3在PHP中使用函数101

5.3.1调用函数101

5.3.2调用未定义的函数103

5.3.3理解字母大小写和函数名称103

5.4理解为什么要定义自己的函数103

5.5了解基本的函数结构104

5.5.1函数命名

5.6使用参数105

5.7理解作用域107

5.8参数的引用传递和值传递109

5.9使用Return关键字110

5.9.1从函数返回一个值111

5.10实现递归113

5.10.1名称空间

5.11进一步学习114

5.12下一章114

第6章面向对象的PHP115

6.1理解面向对象的概念115

6.1.1类和对象115

6.1.2多态性116

6.1.3继承117

6.2在PHP中创建类、属性和操作117

6.2.1类的结构117

6.2.2构造函数118

6.2.3析构函数118

6.3类的实例化118

6.4使用类的属性119

6.5使用private和public关键字控制访问121

6.6类操作的调用121

6.7在PHP中实现继承122

6.7.1通过继承使用private和protected访问修饰符控制可见性123

6.7.2重载124

6.7.3使用final关键字禁止继承和重载125

6.7.4理解多重继承126

6.7.5实现接口126

6.8类的设计127

6.9编写类代码128

6.10理解PHP面向对象新的高级功能135

6.10.1使用Per-Class常量135

6.10.2实现静态方法135

6.10.3检查类的类型和类型提示136

6.10.4克隆对象136

6.10.5使用抽象类137

6.10.6使用__call()重载方法137

6.10.7使用__autoload()方法138

6.10.8实现迭代器和迭代138

6.10.9将类转换成字符串140

6.10.10使用Reflection(反射)API140

6.11下一章141

第7章错误和异常处理142

7.1异常处理的概念142

7.2Exception类144

7.3用户自定义异常144

7.4Bob的汽车零部件商店应用程序的异常146

7.5异常和PHP的其他错误处理机制150

7.6进一步学习150

7.7下一章150

第二篇使用MySQL

第8章设计Web数据库151

8.1关系数据库的概念152

8.1.1表格152

8.1.2列152

8.1.3行152

8.1.4值152

8.1.5键152

8.1.6模式153

8.1.7关系153

8.2如何设计Web数据库154

8.2.1考虑要建模的实际对象154

8.2.2避免保存冗余数据154

8.2.3使用原子列值155

8.2.4选择有意义的键156

8.2.5考虑需要询问数据库的问题156

8.2.6避免多个空属性的设计156

8.2.7表格类型的总结157

8.3Web数据库架构157

8.4进一步学习158

8.5下一章158

第9章创建Web数据库159

9.1使用MySQL监视程序160

9.2登录到MySQL160

9.3创建数据库和用户161

9.4设置用户与权限162

9.5MySQL权限系统的介绍162

9.5.1最少权限原则162

9.5.2创建用户:GRANT命令162

9.5.3权限的类型和级别163

9.5.4REVOKE命令165

9.5.5使用GRANT和REVOKE的例子165

9.6创建一个Web用户166

9.7使用正确的数据库166

9.8创建数据库表167

9.8.1理解其他关键字的意思168

9.8.2理解列的类型169

9.8.3用SHOW和DESCRIBE来查看数据库170

9.8.4创建索引171

9.9理解MySQL的标识符171

9.10选择列数据类型172

9.10.1数字类型173

9.10.2日期和时间类型174

9.10.3字符串类型174

9.11进一步学习176

9.12下一章176

第10章使用MySQL数据库177

10.1SQL是什么177

10.2在数据库中插入数据177

10.3从数据库中获取数据179

10.3.1获取满足特定条件的数据181

10.3.2从多个表中获取数据182

10.3.3以特定的顺序获取数据186

10.3.4分组与合计数据186

10.3.5选择要返回的行188

10.3.6使用子查询188

10.4更新数据库记录190

10.5创建后修改表191

10.6删除数据库中的记录193

10.7表的删除193

10.8删除整个数据库193

10.9进一步学习194

10.10下一章194

第11章使用PHP从Web访问MySQL数据库195

11.1Web数据库架构的工作原理195

11.2从Web查询数据库的基本步骤198

11.2.1检查与过滤用户输入数据198

11.2.2建立一个连接199

11.2.3选择使用的数据库200

11.2.4查询数据库200

11.2.5检索查询结果201

11.2.6从数据库断开连接202

11.3将新信息放入数据库202

11.4使用Prepared语句205

11.5使用PHP与数据库交互的其他接口206

11.5.1使用常规的数据库接口:PEARMDB2206

11.6进一步学习209

11.7下一章209

第12章MySQL高级管理210

12.1深入理解权限系统210

12.1.1user表211

12.1.2db表和host表212

12.1.3tables_priv表,columns_priv表和procs_priv表212

12.1.4访问控制:MySQL如何使用Grant表213

12.1.5更新权限:修改什么时候生效213

12.2提高MySQL数据库的安全性214

12.2.1从操作系统角度来保护MySQL214

12.2.2密码214

12.2.3用户权限215

12.2.4Web问题215

12.3获取更多关于数据库的信息216

12.3.1使用SHOW获取信息216

12.3.2使用DESCRIBE获取关于列的信息218

12.3.3用EXPLAIN理解查询操作的工作过程218

12.4数据库的优化221

12.4.1设计优化222

12.4.2权限222

12.4.3表的优化222

12.4.4使用索引222

12.4.5使用默认值222

12.4.6其他技巧222

12.5备份MySQL数据库222

12.6恢复MySQL数据库223

12.7实现复制223

12.7.1设置主服务器224

12.7.2执行初始的数据传输224

12.7.3设置一个/多个从服务器225

12.8进一步学习225

12.9下一章225

第13章MySQL高级编程226

13.1LOADDATAINFILE语句226

13.2存储引擎226

13.3事务227

13.3.1理解事务的定义227

13.3.2通过InnoDB使用事务228

13.4外键229

13.5存储过程230

13.5.1基本示例230

13.5.2局部变量232

13.5.3游标和控制结构233

13.6进一步学习236

13.7下一章236

第三篇电子商务与安全性

第14章运营一个电子商务网站237

14.1我们要实现什么目标237

14.2考虑电子商务网站的类型237

14.2.1使用在线说明书公布信息238

14.2.2接收产品或服务的订单240

14.2.3提供服务和数字产品243

14.2.4为产品或服务增值243

14.2.5减少成本243

14.3理解风险和威胁244

14.3.1网络黑客244

14.3.2不能招揽足够的生意245

14.3.3计算机硬件故障245

14.3.4电力、通信、网络或运输故障245

14.3.5广泛的竞争245

14.3.6软件错误245

14.3.7不断变化的政府政策和税收246

14.3.8系统容量限制246

14.4选择一个策略246

14.5下一章246

第15章电子商务的安全问题247

15.1信息的重要程度247

15.2安全威胁248

15.2.1机密数据的泄露248

15.2.2数据丢失和数据破坏249

15.2.3数据修改250

15.2.4拒绝服务251

15.2.5软件错误251

15.2.6否认252

15.3易用性,性能、成本和安全性253

15.4建立一个安全政策253

15.5身份验证原则254

15.6加密技术基础255

15.6.1私有密钥加密256

15.6.2公有密钥加密256

15.6.3数字签名256

15.7数字证书257

15.8安全的Web服务器258

15.9审计与日志记录259

15.10防火墙259

15.11备份数据259

15.11.1备份常规文件260

15.11.2备份与恢复MySQL数据库260

15.12自然环境安全260

15.13下一章261

第16章Web应用的安全

16.1处理安全性问题的策略

16.1.1以正确心态为开始

16.1.2安全性和可用性之间的平衡

16.1.3安全监视

16.1.4基本方法

16.2识别所面临的威胁

16.2.1访问或修改敏感数据

16.2.2数据丢失或破坏

16.2.3拒绝服务

16.2.4恶意代码注入

16.2.5服务器被攻破

16.3了解与我们“打交道”的用户

16.3.1破解人员

16.3.2受影响机器的未知情用户

16.3.3对公司不满的员工

16.3.4硬件被盗

16.3.5我们自身

16.4代码的安全性

16.4.1过滤用户输入

16.4.2转义输出

16.4.3代码组织

16.4.4代码自身的问题

16.4.5文件系统因素

16.4.6代码稳定性和缺陷

16.4.7执行引号和exec

16.5Web服务器和PHP的安全性

16.5.1保持软件的更新

16.5.2查看php.ini文件

16.5.3Web服务器配置

16.5.4Web应用的商业主机服务

16.6数据库服务器的安全性

16.6.1用户和权限系统

16.6.2发送数据至服务器

16.6.3连接服务器

16.6.4运行服务器

16.7保护网络

16.7.1安装防火墙

16.7.2使用隔离区域(DMZ)

16.7.3应对DoS和DDoS攻击

16.8计算机和操作系统的安全性

16.8.1保持操作系统的更新

16.8.2只运行必须的软件

16.8.3服务器的物理安全性

16.9灾难计划

16.10下一章

第17章使用PHP和MySQL实现身份验证262

17.1识别访问者262

17.2实现访问控制263

17.2.1保存密码265

17.2.2密码的加密267

17.2.3保护多个网页268

17.3使用基本身份验证269

17.4在PHP中使用基本身份验证270

17.5在Apache的.htaccess文件中使用基本身份验证271

17.6使用mod_auth_mysql身份验证276

17.6.1安装mod_auth_mysql276

17.6.2使用mod_auth_mysql277

17.7创建自定义身份验证277

17.8进一步学习278

17.9下一章278

第18章使用PHP和MySQL实现安全事务279

18.1提供安全的事务处理279

18.1.1用户机器280

18.1.2Internet281

18.1.3我们的系统281

18.2使用加密套接字层(SSL)282

18.3屏蔽用户的输入284

18.4提供安全存储284

18.5存储信用卡号码285

18.6在PHP中使用加密技术286

18.6.1安装GPG286

18.6.2测试GPG288

18.7进一步学习293

18.8下一章293

第四篇PHP的高级技术

第19章与文件系统和服务器的交互295

19.1文件上载295

19.1.1文件上载的HTML代码296

19.1.2编写处理文件的PHP297

19.1.3避免常见上载问题300

19.2使用目录函数300

19.2.1从目录读取300

19.2.2获得当前目录的信息302

19.2.3创建和删除目录302

19.3与文件系统的交互302

19.3.1获取文件信息302

19.3.2更改文件属性304

19.3.3创建、删除和移动文件305

19.4使用程序执行函数305

19.5与环境变量交互:getenv()和putenv()308

19.6进一步学习308

19.7下一章308

第20章使用网络函数和协议函数309

20.1了解可供使用的协议309

20.2发送和读取电子邮件309

20.3使用其他Web站点的数据310

20.4使用网络查找函数312

20.5备份或镜像一个文件

20.5.1使用FTP备份或镜像一个文件316

20.5.2上传文件321

20.5.3避免超时321

20.5.4使用其他的FTP函数322

20.6进一步学习322

20.7下一章323

第21章日期和时间的管理324

21.1在PHP中获取日期和时间324

21.1.1使用date()函数324

21.1.2使用UNIX时间戳325

21.1.3使用getdate()函数326

21.1.4使用checkdate()函数检验日期有效性327

21.1.5格式化时间戳

21.2在PHP日期格式和MySQL日期格式之间进行转换327

21.3在PHP中计算日期329

21.4在MySQL中计算日期329

21.5使用微秒331

21.6使用日历函数331

21.7进一步学习332

21.8下一章332

第22章创建图像333

22.1在PHP中设置图像支持333

22.2理解图像格式334

22.2.1JPEG334

22.2.2PNG334

22.2.3WBMP335

22.2.4GIF335

22.3创建图像335

22.3.1创建一个背景图像336

22.3.2在图像上绘图或打印文本337

22.3.3输出最终图形338

22.3.4清理339

22.4在其他页面中使用自动生成的图像339

22.5使用文本和字体创建图像339

22.5.1创建基本画布342

22.5.2将文本调整到适合按钮342

22.5.3放置文本345

22.5.4将文本写到按钮上345

22.5.5完成345

22.6绘制图像与用图表描绘数据346

22.7使用其他的图像函数352

22.8进一步学习352

22.9下一章353

第23章在PHP中使用会话控制354

23.1什么是会话控制354

23.2理解基本的会话功能354

23.2.1什么是cookie354

23.2.2通过PHP设置cookie355

23.2.3在会话中使用cookie355

23.2.4存储会话ID356

23.3实现简单的会话356

23.3.1开始一个会话356

23.3.2注册一个会话变量356

23.3.3使用会话变量357

23.3.4注销变量与销毁会话357

23.4创建一个简单的会话例子357

23.5配置会话控制359

23.6通过会话控制实现身份验证360

23.7进一步学习365

23.8下一章365

第24章其他有用的特性366

24.1使用eval()函数对字符串求值367

24.2终止执行:die和exit367

24.3序列化变量和对象368

24.4获取PHP环境信息369

24.4.1找到所加载的PHP扩展部件369

24.4.2识别脚本所有者370

24.4.3确定脚本最近修改时间370

24.5暂时改变运行时环境370

24.6源代码加亮371

24.7在命令行中使用PHP372

24.8下一章372

第五篇创建实用的PHP和MySQL项目

第25章在大型项目中使用PHP和MySQL373

25.1在Web开发中应用软件工程374

25.2规划和运行Web应用程序项目374

25.3重用代码375

25.4编写可维护代码375

25.4.1编码标准375

25.4.2分解代码378

25.4.3使用标准的目录结构378

25.4.4文档化和共享内部函数378

25.5实现版本控制379

25.6选择一个开发环境380

25.7项目的文档化380

25.8建立原型381

25.9将逻辑和内容分离381

25.10优化代码382

25.10.1使用简单优化382

25.10.2使用Zend产品382

25.11测试383

25.12进一步学习383

25.13下一章384

第26章调试385

26.1编程错误385

26.1.1语法错误385

26.1.2运行时错误386

26.1.3逻辑错误391

26.2使用变量帮助调试392

26.3错误报告级别393

26.4改变错误报告设置394

26.5触发自定义错误395

26.6巧妙地处理错误396

26.7下一章398

第27章建立用户身份验证机制和个性化设置399

27.1解决方案的组成399

27.1.1用户识别和个性化设置399

27.1.2保存书签400

27.1.3推荐书签400

27.2解决方案概述400

27.3实现数据库402

27.4实现基本的网站403

27.5实现用户身份验证405

27.5.1注册405

27.5.2登录410

27.5.3登出413

27.5.4修改密码414

27.5.5重设遗忘的密码416

27.6实现书签的存储和检索420

27.6.1添加书签420

27.6.2显示书签422

27.6.3删除书签422

27.7实现书签推荐424

27.8考虑可能的扩展427

27.9下一章427

第28章创建一个购物车428

28.1解决方案的组成428

28.1.1创建一个在线目录428

28.1.2在用户购买商品的时候记录购买行为429

28.1.3实现一个付款系统429

28.1.4创建一个管理界面429

28.2解决方案概述429

28.3实现数据库432

28.4实现在线目录434

28.4.1列出目录434

28.4.2列出一个目录中的所有图书437

28.4.3显示图书详细信息438

28.5实现购物车440

28.5.1使用show_cart.php脚本440

28.5.2浏览购物车442

28.5.3将物品添加到购物库444

28.5.4保存更新后的购物车446

28.5.5打印标题栏摘要447

28.5.6结账447

28.6实现付款452

28.7实现一个管理界面454

28.8扩展该项目460

28.9使用一个已有系统461

28.10下一章461

第29章创建一个基于Web的电子邮件服务系统486

29.1解决方案的组成486

29.1.1电子邮件协议:POP3和IMAP

29.1.2PHP对POP3和IMAP的支持

29.2解决方案概述488

29.3建立数据库489

29.4了解脚本架构490

29.5登录与登出495

29.6建立账户498

29.6.1创建一个新账户499

29.6.2修改已有账户501

29.6.3删除账户501

29.7阅读邮件502

29.7.1选择账户502

29.7.2查看邮箱内容504

29.7.3阅读邮件消息507

29.7.4查看消息标题509

29.7.5删除邮件509

29.8发送邮件510

29.8.1发送一则新消息510

29.8.2回复或转发邮件512

29.9扩展这个项目514

29.10下一章514

第30章创建一个邮件列表管理器515

30.1解决方案的组成515

30.1.1建立列表和订阅者数据库516

30.1.2上载新闻信件516

30.1.3发送带附件的邮件516

30.2解决方案概述516

30.3建立数据库518

30.4定义脚本架构520

30.5实现登录526

30.5.1新账户的创建527

30.5.2登录529

30.6用户函数的实现531

30.6.1查看列表531

30.6.2查看邮件列表信息535

30.6.3查看邮件列表存档536

30.6.4订阅与取消订阅538

30.6.5更改账户设置539

30.6.6更改密码539

30.6.7登出540

30.7管理功能的实现541

30.7.1创建新的邮件列表541

30.7.2上载新的新闻信件543

30.7.3多文件上载的处理545

30.7.4预览新闻信件549

30.7.5发送邮件550

30.8扩展这个项目555

30.9下一章555

第31章创建一个Web论坛556

31.1理解流程

31.2解决方案的组成556

31.3解决方案概述557

31.4数据库的设计558

31.5查看文章的树型结构560

31.5.1展开和折叠561

31.5.2显示文章564

31.5.3使用treenode类564

31.6查看单个的文章570

31.7添加新文章572

31.8添加扩充578

31.9使用一个已有的系统578

31.10下一章578

第32章生成PDF格式的个性化文档579

32.1项目概述

32.1.1评估文档格式579

32.2解决方案的组成582

32.2.1问题与回答系统583

32.2.2文档生成软件583

32.3解决方案概述585

32.3.1提问585

32.3.2给答题评分587

32.3.3生成RTF证书589

32.3.4从模板生成PDF证书591

32.3.5使用PDFlib生成PDF文档595

32.3.6使用PDFlib的一个“HelloWorld”程序595

32.3.7用PDFlib生成证书598

32.4处理标题的问题605

32.5扩展该项目605

32.6下一章606

第33章使用XML和SOAP来连接Web服务607

33.1项目概述:使用XML和Web服务

33.1.1理解XML

33.1.2理解Web服务611

33.2解决方案的组成612

33.2.1使用Amazon的Web服务接口613

33.2.2XML的解析:REST响应

33.2.3在PHP中使用SOAP614

33.2.4缓存614

33.3解决方案概述614

33.3.1核心应用程序618

33.3.2显示特定种类的图书623

33.3.3获得一个AmazonResultSet类624

33.3.4使用REST发送和接收请求

33.3.5使用SOAP发送和接收请求

33.3.6缓存请求返回的数据636

33.3.7创建购物车639

33.3.8到Amazon付账642

33.4安装项目代码642

33.5扩展这个项目643

33.6进一步学习643

第34章使用Ajax构建Web2.0应用

34.1Ajax是什么?

34.1.1HTTP请求和响应

34.1.2DHTML和XHTML

34.1.3级联样式单(CSS)

34.1.4客户端编程

34.1.5服务器端编程

34.1.6XML和XSLT

34.2Ajax基础

34.2.1XMLHTTPRequest对象

34.2.2与服务器通信

34.2.3处理服务器响应

34.2.4整合应用

34.3在以前的项目添加Ajax元素

34.3.1在PHPBookmark应用中添加Ajax元素

34.4进一步学习

34.4.1进一步了解文档对象模型(DOM)

34.4.2Ajax应用可用的JavaScript函数库

34.4.3Ajax开发人员网站

第六篇附录

附录A安装PHP及MySQL645

附录BWeb资源664

第1章PHP快速入门教程

第2章数据的存储与检索

第3章使用数组

第4章字符串操作与正则表达式

第5章代码重用与函数编写

第6章面向对象的PHP

第7章错误和异常处理

……