1、存储引擎
MySQL支持许多不同的“存储引擎”,也叫作“表格类型”。每个表可是使用不同的存储引擎,而且可以轻松地对它们进行转换。
创建表时可以选择一个表格类型:
CREATE TABLE table TYPE = type....
修改表类型:
alter table orders type = innodb;
1)MyISAM,默认类型
它基于传统的ISAM类型,Indexed Sequential Access Method(有索引的顺序访问方法)的缩写,它是存储记录和文件的标准方法。
MyISAM特点:
MyISAM具有检查和修复表格的大多数工具,表格可以被压缩,支持全文搜索。但是它们不是事务安全的,也不支持外键。
2)InnoDB
该类型表是事务安全的,也就是说,它提供了 COMMIT 和 ROLLBACK功能。InnoDB支持外键。 虽然比MyISAM表要慢些,但是如果应用程序需要一个事务安全的存储引擎,建议使用。
注:在大多数Web应用程序中,通常都会使用MyISAM或InnoDB表格或者二者的结合。
3)MEMORY (以前的 HEAP)
该类型表,存储在内存中,表的索引是哈希分布的。
MEMORY表格运行速度非常快,但是如果发生崩溃,数据将丢失。
建议:MEMORY表格适合保存临时或者派生的数据,应该在CREATE TABLE语句中指定MAX_ROWS,否则这些表可能吞噬所有内存。同样,它们不能加入BLOB、TEXT或AUTO INCREMENT列。
4)MERGE
这些表允许你为了查询目的,把MyISAM表的集合作为一个单个表。因此,你可在某些操作系统中,避开最大文件大小限制。
5)ARCHIVE
这些表保存了大量数据,但是只有少量脚注(footprint)。这种类型的表只支持INSERT 和SELECT 查询。不支持DELETE、UPDATE 和 REPLACE。此外,也不使用索引。
6)CSV
这些表保存在服务器的单个文件中,它包含用逗号隔离的数据。
可以方便地用Excel等第三方工具打开。
建议:
当对一个表格使用大量的SELECT 和 INSERT 语句(或者二者结合)时,应该使用MyISAM 表格,因为在执行这两种命令时,MyISAM是最快的。对于很多Web程序(例如分类)来说,MyISAM是最佳选择。如果需要全文搜索功能,也应该使用MyISAM功能。
当事务非常重要(例如存储财务数据),或在INSERT 和 SELECT 语句是交错执行的情况下(例如在线的消息栏或论坛系统),应该使用 InnoDB。InnoDB在MySQL5.6版本中好像支持全文索引了。
2、事务
事务是确保数据库一致的机制,尤其是在发生错误或服务器崩溃情况下确保数据库一致的机制。
事务是一个或一系列的查询,这些查询可以保证能够在数据库中作为一个整体全部执行或者全部不执行。这样,数据库才能在无论事务是否完成的情况下保持一致状态。
比如,银行转账,比如保证从一个账户减少和另一个账户增加的操作完整完成。
ACID原则,就是描述事务安全性的4个需求:
Atomicity(原子性)---一个事务必须是原子性的,它必须是作为一个整体完全执行或者完全不执行。
Consistency(一致性)---一个事务必须能够使数据库处于一致的状态。
Isoltion(孤立性)---未完全完成的事务不能被数据库的其他用户所见,也就是说,在事务完全完成之前,它们都是孤立的。
Durability(持续性)---一旦写入到数据库后,事务必须是永久的而且持续的。
注意:一个事务被永久地写入到数据库中称作该事务被提交了。一个没有写入到数据库中的事务(因此数据库将状态重置到事务开始之前的状态)称作事务被回滚了。
3、关系数据库
关系数据库代替普通文件的优点:
1)关系数据库比普通文件的数据访问速度更快。
2)关系数据库更容易查询并提取满足特定条件的数据。
3)关系数据库具有专门的内置机制处理并发访问。
4)关系数据库可以提供对数据的随机访问
5)关系数据库具有内置的权限系统。
4、关系数据库的一些基本概念
1)关系数据库由“关系”组成,这些关系通常称为“表格”
2)列
“列”又叫做“域”或者“属性”
每一列都有一个唯一的名称,和一个相关的数据类型。
3)行
每一行具有相同的格式,也具有相同的属性。行也叫“记录”。
4)值
每个值必须与该列定义的数据类型相同。
5)键
我们必须有一个能够识别每一个特定记录的方法。
表中的标志列成为“键”或“主键”。
数据库由多个表组成,可以使用键作为表格之间的引用。
6)模式
数据库整套表格的完整设计称为数据库的“模式”。它是数据库的设计蓝图。
一个模式应该显示表格及表格的列、各个表的主键和外键。
可以包含示例数据来解析这些数据的含义。
7)关系
关系数据库中有3种基本的关系类型,一对一、一对多、多对多。
4、设计Web数据库
知道什么时候需要一个新表,以及需要哪些键,需要掌握很高的技巧。但是在大多数情况下,我们可以遵循一些基本的原则。
1)考虑实际建模的对象,现实世界对应的对象
2)避免冗余数据
冗余数据将导致两个主要问题:
a. 空间的浪费
b. 数据更新的不一致,数据的完整性将被破坏。(修改、插入和删除时容易导致)
c. 使用原子列值:每一行的每个属性只存储一个数据。
如果我们想在格子里存多个数据值,其实相当于创建了一个表中表,这样系统就不能只计算匹配字段了,而必须分析每个属性值,看系统中是否包含一个匹配。所以,看情况而定吧。
d. 选择有意义的键
e. 考虑需要询问数据库的问题,想一想我们希望数据库回答什么问题,然后确认数据库中是否已经包含所有需要的数据,并且在表之间要有适当的关联。
f. 避免多个空属性的设计。
数据库里有很多空值,很糟糕。首先,浪费空间。其次,在统计列总量或对其他数值列应用计算函数时可能导致错误。还有,当用户看到表中一部分为空时。也很迷惑,他们也不知道是否因为该属性是无关的,还是数据库中有错误,或者是数据尚未输入。
5、表类型总结
1)描述现实世界对象的简单表
2)描述两个现实世界对象的多对多关系的关联表。
6、Web数据库的架构
通常,Web服务器软件,PHP引擎和数据库服务器都在同一台机器上运行。但是数据库服务器在另外一台机器上运行也很常见,这样是出于安全性、提高性能以及负载均衡的原因。
随着应用程序在大小和复杂度上不断增加,我们可能会将PHP应用程序分成不同的层,通常,包括与MySQL交互的数据库层、包含了应用程序的业务逻辑成、管理HTML输出的表示层。

PHP在现代编程中仍然是一个强大且广泛使用的工具,尤其在web开发领域。1)PHP易用且与数据库集成无缝,是许多开发者的首选。2)它支持动态内容生成和面向对象编程,适合快速创建和维护网站。3)PHP的性能可以通过缓存和优化数据库查询来提升,其广泛的社区和丰富生态系统使其在当今技术栈中仍具重要地位。

在PHP中,弱引用是通过WeakReference类实现的,不会阻止垃圾回收器回收对象。弱引用适用于缓存系统和事件监听器等场景,需注意其不能保证对象存活,且垃圾回收可能延迟。

\_\_invoke方法允许对象像函数一样被调用。1.定义\_\_invoke方法使对象可被调用。2.使用$obj(...)语法时,PHP会执行\_\_invoke方法。3.适用于日志记录和计算器等场景,提高代码灵活性和可读性。

Fibers在PHP8.1中引入,提升了并发处理能力。1)Fibers是一种轻量级的并发模型,类似于协程。2)它们允许开发者手动控制任务的执行流,适合处理I/O密集型任务。3)使用Fibers可以编写更高效、响应性更强的代码。

PHP社区提供了丰富的资源和支持,帮助开发者成长。1)资源包括官方文档、教程、博客和开源项目如Laravel和Symfony。2)支持可以通过StackOverflow、Reddit和Slack频道获得。3)开发动态可以通过关注RFC了解。4)融入社区可以通过积极参与、贡献代码和学习分享来实现。

PHP和Python各有优势,选择应基于项目需求。1.PHP适合web开发,语法简单,执行效率高。2.Python适用于数据科学和机器学习,语法简洁,库丰富。

PHP不是在消亡,而是在不断适应和进化。1)PHP从1994年起经历多次版本迭代,适应新技术趋势。2)目前广泛应用于电子商务、内容管理系统等领域。3)PHP8引入JIT编译器等功能,提升性能和现代化。4)使用OPcache和遵循PSR-12标准可优化性能和代码质量。

PHP的未来将通过适应新技术趋势和引入创新特性来实现:1)适应云计算、容器化和微服务架构,支持Docker和Kubernetes;2)引入JIT编译器和枚举类型,提升性能和数据处理效率;3)持续优化性能和推广最佳实践。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

记事本++7.3.1
好用且免费的代码编辑器

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境