php3数据字典教程 php 文本数据库

PHP查询结果如何对变量值进行排序?比如说一个评分系统,对每个人员的每项评分相加后的总分再进行排序!数据库设计方法、规范与技巧
一、数据库设计过程
数据库技术是信息资源管理最有效php3数据字典教程的手段 。数据库设计是指对于一个给定的应用环境,构造最优的数据库模式 , 建立数据库及其应用系统,有效存储数据,满足用户信息要求和处理要求 。
数据库设计中需求分析阶段综合各个用户的应用需求(现实世界的需求) , 在概念设计阶段形成独立于机器特点、独立于各个DBMS产品的概念模式(信息世界模型) , 用E-R图来描述 。在逻辑设计阶段将E-R图转换成具体的数据库产品支持的数据模型如关系模型,形成数据库逻辑模式 。然后根据用户处理的要求,安全性的考虑,在基本表的基础上再建立必要的视图(VIEW)形成数据的外模式 。在物理设计阶段根据DBMS特点和处理的需要 , 进行物理存储安排,设计索引,形成数据库内模式 。
1. 需求分析阶段
需求收集和分析 , 结果得到数据字典描述的数据需求(和数据流图描述的处理需求) 。
需求分析的重点是调查、收集与分析用户在数据管理中的信息要求、处理要求、安全性与完整性要求 。
需求分析的方法php3数据字典教程:调查组织机构情况、调查各部门的业务活动情况、协助用户明确对新系统的各种要求、确定新系统的边界 。
常用的调查方法有php3数据字典教程: 跟班作业、开调查会、请专人介绍、询问、设计调查表请用户填写、查阅记录 。
分析和表达用户需求的方法主要包括自顶向下和自底向上两类方法 。自顶向下的结构化分析方法(Structured Analysis,简称SA方法)从最上层的系统组织机构入手,采用逐层分解的方式分析系统,并把每一层用数据流图和数据字典描述 。
数据流图表达了数据和处理过程的关系 。系统中的数据则借助数据字典(Data Dictionary , 简称DD)来描述 。
数据字典是各类数据描述的集合,它是关于数据库中数据的描述,即元数据,而不是数据本身 。数据字典通常包括数据项、数据结构、数据流、数据存储和处理过程五个部分(至少应该包含每个字段的数据类型和在每个表内的主外键) 。
数据项描述={数据项名,数据项含义说明,别名 , 数据类型,长度,
取值范围,取值含义,与其php3数据字典教程他数据项的逻辑关系}
数据结构描述={数据结构名 , 含义说明 , 组成:{数据项或数据结构}}
数据流描述={数据流名,说明,数据流来源,数据流去向,
组成:{数据结构},平均流量,高峰期流量}
数据存储描述={数据存储名,说明,编号 , 流入的数据流,流出的数据流,
组成:{数据结构} , 数据量,存取方式}
处理过程描述={处理过程名,说明,输入:{数据流},输出:{数据流},
处理:{简要说明}}
2. 概念结构设计阶段
通过对用户需求进行综合、归纳与抽象,形成一个独立于具体DBMS的概念模型,可以用E-R图表示 。
概念模型用于信息世界的建模 。概念模型不依赖于某一个DBMS支持的数据模型 。概念模型可以转换为计算机上某一DBMS支持的特定数据模型 。
概念模型特点:
(1) 具有较强的语义表达能力,能够方便、直接地表达应用中的各种语义知识 。
(2) 应该简单、清晰、易于用户理解,是用户与数据库设计人员之间进行交流的语言 。
概念模型设计的一种常用方法为IDEF1X方法,它就是把实体-联系方法应用到语义数据模型中的一种语义模型化技术,用于建立系统信息模型 。
使用IDEF1X方法创建E-R模型的步骤如下所示:
2.1 第零步——初始化工程
这个阶段的任务是从目的描述和范围描述开始,确定建模目标,开发建模计划,组织建模队伍,收集源材料,制定约束和规范 。收集源材料是这阶段的重点 。通过调查和观察结果,业务流程,原有系统的输入输出,各种报表 , 收集原始数据,形成了基本数据资料表 。
2.2 第一步——定义实体
实体集成员都有一个共同的特征和属性集,可以从收集的源材料——基本数据资料表中直接或间接标识出大部分实体 。根据源材料名字表中表示物的术语以及具有“代码”结尾的术语 , 如客户代码、代理商代码、产品代码等将其名词部分代表的实体标识出来,从而初步找出潜在的实体 , 形成初步实体表 。
2.3 第二步——定义联系
IDEF1X模型中只允许二元联系 , n元联系必须定义为n个二元联系 。根据实际的业务需求和规则,使用实体联系矩阵来标识实体间的二元关系,然后根据实际情况确定出连接关系的势、关系名和说明,确定关系类型,是标识关系、非标识关系(强制的或可选的)还是非确定关系、分类关系 。如果子实体的每个实例都需要通过和父实体的关系来标识,则为标识关系,否则为非标识关系 。非标识关系中,如果每个子实体的实例都与而且只与一个父实体关联 , 则为强制的,否则为非强制的 。如果父实体与子实体代表的是同一现实对象 , 那么它们为分类关系 。
2.4 第三步——定义码
通过引入交叉实体除去上一阶段产生的非确定关系,然后从非交叉实体和独立实体开始标识侯选码属性,以便唯一识别每个实体的实例,再从侯选码中确定主码 。为了确定主码和关系的有效性,通过非空规则和非多值规则来保证,即一个实体实例的一个属性不能是空值,也不能在同一个时刻有一个以上的值 。找出误认的确定关系 , 将实体进一步分解,最后构造出IDEF1X模型的键基视图(KB图) 。
2.5 第四步——定义属性
从源数据表中抽取说明性的名词开发出属性表,确定属性的所有者 。定义非主码属性,检查属性的非空及非多值规则 。此外,还要检查完全依赖函数规则和非传递依赖规则,保证一个非主码属性必须依赖于主码、整个主码、仅仅是主码 。以此得到了至少符合关系理论第三范式的改进的IDEF1X模型的全属性视图 。
2.6 第五步——定义其他对象和规则
定义属性的数据类型、长度、精度、非空、缺省值、约束规则等 。定义触发器、存储过程、视图、角色、同义词、序列等对象信息 。
3. 逻辑结构设计阶段
将概念结构转换为某个DBMS所支持的数据模型(例如关系模型),并对其进行优化 。设计逻辑结构应该选择最适于描述与表达相应概念结构的数据模型 , 然后选择最合适的DBMS 。
将E-R图转换为关系模型实际上就是要将实体、实体的属性和实体之间的联系转化为关系模式,这种转换一般遵循如下原则:
1)一个实体型转换为一个关系模式 。实体的属性就是关系的属性 。实体的码就是关系的码 。
2)一个m:n联系转换为一个关系模式 。与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性 。而关系的码为各实体码的组合 。
3)一个1:n联系可以转换为一个独立的关系模式,也可以与n端对应的关系模式合并 。如果转换为一个独立的关系模式 , 则与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,而关系的码为n端实体的码 。
4)一个1:1联系可以转换为一个独立的关系模式,也可以与任意一端对应的关系模式合并 。
5)三个或三个以上实体间的一个多元联系转换为一个关系模式 。与该多元联系相连的各实体的码以及联系本身的属性均转换为关系的属性 。而关系的码为各实体码的组合 。
6)同一实体集的实体间的联系 , 即自联系,也可按上述1:1、1:n和m:n三种情况分别处理 。
7)具有相同码的关系模式可合并 。
为了进一步提高数据库应用系统的性能,通常以规范化理论为指导 , 还应该适当地修改、调整数据模型的结构,这就是数据模型的优化 。确定数据依赖 。消除冗余的联系 。确定各关系模式分别属于第几范式 。确定是否要对它们进行合并或分解 。一般来说将关系分解为3NF的标准 , 即:
表内的每一个值都只能被表达一次 。
??表内的每一行都应该被唯一的标识(有唯一键) 。
表内不应该存储依赖于其他键的非键信息 。
4. 数据库物理设计阶段
为逻辑数据模型选取一个最适合应用环境的物理结构(包括存储结构和存取方法) 。根据DBMS特点和处理的需要,进行物理存储安排 , 设计索引,形成数据库内模式 。
5. 数据库实施阶段
运用DBMS提供的数据语言(例如SQL)及其宿主语言(例如C),根据逻辑设计和物理设计的结果建立数据库,编制与调试应用程序,组织数据入库 , 并进行试运行 。数据库实施主要包括以下工作:用DDL定义数据库结构、组织数据入库 、编制与调试应用程序、数据库试运行 6. 数据库运行和维护阶段
数据库应用系统经过试运行后即可投入正式运行 。在数据库系统运行过程中必须不断地对其进行评价、调整与修改 。包括:数据库的转储和恢复、数据库的安全性、完整性控制、数据库性能的监督、分析和改进、数据库的重组织和重构造 。
建模工具的使用
为加快数据库设计速度,目前有很多数据库辅助工具(CASE工具),如Rational公司的Rational Rose , CA公司的Erwin和Bpwin,Sybase公司的PowerDesigner以及Oracle公司的Oracle Designer等 。
ERwin主要用来建立数据库的概念模型和物理模型 。它能用图形化的方式,描述出实体、联系及实体的属性 。ERwin支持IDEF1X方法 。通过使用ERwin建模工具自动生成、更改和分析IDEF1X模型 , 不仅能得到优秀的业务功能和数据需求模型,而且可以实现从IDEF1X模型到数据库物理设计的转变 。ERwin工具绘制的模型对应于逻辑模型和物理模型两种 。在逻辑模型中,IDEF1X工具箱可以方便地用图形化的方式构建和绘制实体联系及实体的属性 。在物理模型中,ERwin可以定义对应的表、列,并可针对各种数据库管理系统自动转换为适当的类型 。
设计人员可根据需要选用相应的数据库设计建模工具 。例如需求分析完成之后,设计人员可以使用Erwin画ER图,将ER图转换为关系数据模型,生成数据库结构;画数据流图,生成应用程序 。
二、数据库设计技巧
1. 设计数据库之前(需求分析阶段)
1) 理解客户需求,询问用户如何看待未来需求变化 。让客户解释其需求,而且随着开发的继续,还要经常询问客户保证其需求仍然在开发的目的之中 。
2) 了解企业业务可以在以后的开发阶段节约大量的时间 。
3) 重视输入输出 。
在定义数据库表和字段需求(输入)时,首先应检查现有的或者已经设计出的报表、查询和视图(输出)以决定为了支持这些输出哪些是必要的表和字段 。
举例:假如客户需要一个报表按照邮政编码排序、分段和求和 , 你要保证其中包括了单独的邮政编码字段而不要把邮政编码糅进地址字段里 。
4) 创建数据字典和ER 图表
ER 图表和数据字典可以让任何了解数据库的人都明确如何从数据库中获得数据 。ER图对表明表之间关系很有用,而数据字典则说明了每个字段的用途以及任何可能存在的别名 。对SQL 表达式的文档化来说这是完全必要的 。
5) 定义标准的对象命名规范
数据库各种对象的命名必须规范 。
2. 表和字段的设计(数据库逻辑设计)
表设计原则
1) 标准化和规范化
数据的标准化有助于消除数据库中的数据冗余 。标准化有好几种形式,但Third Normal Form(3NF)通常被认为在性能、扩展性和数据完整性方面达到了最好平衡 。简单来说,遵守3NF 标准的数据库的表设计原则是:“One Fact in One Place”即某个表只包括其本身基本的属性 , 当不是它们本身所具有的属性时需进行分解 。表之间的关系通过外键相连接 。它具有以下特点:有一组表专门存放通过键连接起来的关联数据 。
举例:某个存放客户及其有关定单的3NF 数据库就可能有两个表:Customer 和Order 。Order 表不包含定单关联客户的任何信息,但表内会存放一个键值,该键指向Customer 表里包含该客户信息的那一行 。
事实上,为了效率的缘故,对表不进行标准化有时也是必要的 。
2) 数据驱动
采用数据驱动而非硬编码的方式 , 许多策略变更和维护都会方便得多,大大增强系统的灵活性和扩展性 。
举例,假如用户界面要访问外部数据源(文件、XML 文档、其他数据库等),不妨把相应的连接和路径信息存储在用户界面支持表里 。还有 , 如果用户界面执行工作流之类的任务(发送邮件、打印信笺、修改记录状态等),那么产生工作流的数据也可以存放在数据库里 。角色权限管理也可以通过数据驱动来完成 。事实上,如果过程是数据驱动的 , 你就可以把相当大的责任推给用户,由用户来维护自己的工作流过程 。
3) 考虑各种变化
在设计数据库的时候考虑到哪些数据字段将来可能会发生变更 。举例,姓氏就是如此(注意是西方人的姓氏 , 比如女性结婚后从夫姓等) 。所以,在建立系统存储客户信息时,在单独的一个数据表里存储姓氏字段,而且还附加起始日和终止日等字段,这样就可以跟踪这一数据条目的变化 。
字段设计原则
4) 每个表中都应该添加的3 个有用的字段
??dRecordCreationDate , 在VB 下默认是Now(),而在SQL Server 下默认为GETDATE()
??sRecordCreator , 在SQL Server 下默认为NOT NULL DEFAULT USER
??nRecordVersion,记录的版本标记;有助于准确说明记录中出现null 数据或者丢失数据的原因
5) 对地址和电话采用多个字段
描述街道地址就短短一行记录是不够的 。Address_Line1、Address_Line2 和Address_Line3 可以提供更大的灵活性 。还有,电话号码和邮件地址最好拥有自己的数据表,其间具有自身的类型和标记类别 。
6) 使用角色实体定义属于某类别的列
在需要对属于特定类别或者具有特定角色的事物做定义时,可以用角色实体来创建特定的时间关联关系,从而可以实现自我文档化 。
举例:用PERSON 实体和PERSON_TYPE 实体来描述人员 。比方说 , 当John Smith, Engineer 提升为John Smith, Director 乃至最后爬到John Smith, CIO 的高位,而所有你要做的不过是改变两个表PERSON 和PERSON_TYPE 之间关系的键值,同时增加一个日期/时间字段来知道变化是何时发生的 。这样,你的PERSON_TYPE 表就包含了所有PERSON 的可能类型 , 比如Associate、Engineer、Director、CIO 或者CEO 等 。还有个替代办法就是改变PERSON 记录来反映新头衔的变化,不过这样一来在时间上无法跟踪个人所处位置的具体时间 。
7) 选择数字类型和文本类型尽量充足
在SQL 中使用smallint 和tinyint 类型要特别小心 。比如,假如想看看月销售总额,总额字段类型是smallint,那么,如果总额超过了$32,767 就不能进行计算操作了 。
而ID 类型的文本字段 , 比如客户ID 或定单号等等都应该设置得比一般想象更大 。假设客户ID 为10 位数长 。那你应该把数据库表字段的长度设为12 或者13 个字符长 。但这额外占据的空间却无需将来重构整个数据库就可以实现数据库规模的增长了 。
8) 增加删除标记字段
在表中包含一个“删除标记”字段,这样就可以把行标记为删除 。在关系数据库里不要单独删除某一行;最好采用清除数据程序而且要仔细维护索引整体性 。
3. 选择键和索引(数据库逻辑设计)
键选择原则:
1) 键设计4 原则
??为关联字段创建外键 。
??所有的键都必须唯一 。
??避免使用复合键 。
??外键总是关联唯一的键字段 。
2) 使用系统生成的主键
设计数据库的时候采用系统生成的键作为主键,那么实际控制了数据库的索引完整性 。这样,数据库和非人工机制就有效地控制了对存储数据中每一行的访问 。采用系统生成键作为主键还有一个优点:当拥有一致的键结构时 , 找到逻辑缺陷很容易 。
3) 不要用用户的键(不让主键具有可更新性)
在确定采用什么字段作为表的键的时候 , 可一定要小心用户将要编辑的字段 。通常的情况下不要选择用户可编辑的字段作为键 。
4) 可选键有时可做主键
把可选键进一步用做主键,可以拥有建立强大索引的能力 。
索引使用原则:
索引是从数据库中获取数据的最高效方式之一 。95%的数据库性能问题都可以采用索引技术得到解决 。
1) 逻辑主键使用唯一的成组索引,对系统键(作为存储过程)采用唯一的非成组索引 , 对任何外键列采用非成组索引 。考虑数据库的空间有多大 , 表如何进行访问 , 还有这些访问是否主要用作读写 。
2) 大多数数据库都索引自动创建的主键字段,但是可别忘了索引外键,它们也是经常使用的键,比如运行查询显示主表和所有关联表的某条记录就用得上 。
3) 不要索引memo/note 字段,不要索引大型字段(有很多字符),这样作会让索引占用太多的存储空间 。
4) 不要索引常用的小型表
不要为小型数据表设置任何键,假如它们经常有插入和删除操作就更别这样作了 。对这些插入和删除操作的索引维护可能比扫描表空间消耗更多的时间 。
4. 数据完整性设计(数据库逻辑设计)
1) 完整性实现机制:
实体完整性:主键
【php3数据字典教程 php 文本数据库】参照完整性:
父表中删除数据:级联删除;受限删除;置空值
父表中插入数据:受限插入;递归插入
父表中更新数据:级联更新;受限更新;置空值
DBMS对参照完整性可以有两种方法实现:外键实现机制(约束规则)和触发器实现机制
用户定义完整性:
NOT NULL;CHECK;触发器
2) 用约束而非商务规则强制数据完整性
采用数据库系统实现数据的完整性 。这不但包括通过标准化实现的完整性而且还包括数据的功能性 。在写数据的时候还可以增加触发器来保证数据的正确性 。不要依赖于商务层保证数据完整性;它不能保证表之间(外键)的完整性所以不能强加于其他完整性规则之上 。
3) 强制指示完整性
在有害数据进入数据库之前将其剔除 。激活数据库系统的指示完整性特性 。这样可以保持数据的清洁而能迫使开发人员投入更多的时间处理错误条件 。
4) 使用查找控制数据完整性
控制数据完整性的最佳方式就是限制用户的选择 。只要有可能都应该提供给用户一个清晰的价值列表供其选择 。这样将减少键入代码的错误和误解同时提供数据的一致性 。某些公共数据特别适合查找:国家代码、状态代码等 。
5) 采用视图
为了在数据库和应用程序代码之间提供另一层抽象,可以为应用程序建立专门的视图而不必非要应用程序直接访问数据表 。这样做还等于在处理数据库变更时给你提供了更多的自由 。
5. 其他设计技巧
1) 避免使用触发器
触发器的功能通常可以用其他方式实现 。在调试程序时触发器可能成为干扰 。假如你确实需要采用触发器,你最好集中对它文档化 。
2) 使用常用英语(或者其他任何语言)而不要使用编码
在创建下拉菜单、列表、报表时最好按照英语名排序 。假如需要编码,可以在编码旁附上用户知道的英语 。
3) 保存常用信息
让一个表专门存放一般数据库信息非常有用 。在这个表里存放数据库当前版本、最近检查/修复(对Access)、关联设计文档的名称、客户等信息 。这样可以实现一种简单机制跟踪数据库,当客户抱怨他们的数据库没有达到希望的要求而与你联系时,这样做对非客户机/服务器环境特别有用 。
4) 包含版本机制
在数据库中引入版本控制机制来确定使用中的数据库的版本 。时间一长,用户的需求总是会改变的 。最终可能会要求修改数据库结构 。把版本信息直接存放到数据库中更为方便 。
5) 编制文档
对所有的快捷方式、命名规范、限制和函数都要编制文档 。
采用给表、列、触发器等加注释的数据库工具 。对开发、支持和跟踪修改非常有用 。
对数据库文档化,或者在数据库自身的内部或者单独建立文档 。这样,当过了一年多时间后再回过头来做第2 个版本,犯错的机会将大大减少 。
6) 测试、测试、反复测试
建立或者修订数据库之后,必须用用户新输入的数据测试数据字段 。最重要的是,让用户进行测试并且同用户一道保证选择的数据类型满足商业要求 。测试需要在把新数据库投入实际服务之前完成 。
7) 检查设计
在开发期间检查数据库设计的常用技术是通过其所支持的应用程序原型检查数据库 。换句话说,针对每一种最终表达数据的原型应用 , 保证你检查了数据模型并且查看如何取出数据 。
三、数据库命名规范
1. 实体(表)的命名
1) 表以名词或名词短语命名 , 确定表名是采用复数还是单数形式,此外给表的别名定义简单规则(比方说,如果表名是一个单词,别名就取单词的前4 个字母;如果表名是两个单词,就各取两个单词的前两个字母组成4 个字母长的别名;如果表的名字由3 个单词组成,从头两个单词中各取一个然后从最后一个单词中再取出两个字母,结果还是组成4 字母长的别名 , 其余依次类推)
对工作用表来说 , 表名可以加上前缀WORK_ 后面附上采用该表的应用程序的名字 。在命名过程当中 , 根据语义拼凑缩写即可 。注意,由于ORCLE会将字段名称统一成大写或者小写中的一种,所以要求加上下划线 。
举例:
定义的缩写 Sales: Sal 销售;
Order: Ord 订单;
Detail: Dtl 明细;
则销售订单明细表命名为:Sal_Ord_Dtl;
2) 如果表或者是字段的名称仅有一个单词,那么建议不使用缩写,而是用完整的单词 。
举例:
定义的缩写 Material Ma 物品;
物品表名为:Material, 而不是 Ma.
但是字段物品编码则是:Ma_ID;而不是Material_ID
3) 所有的存储值列表的表前面加上前缀Z
目的是将这些值列表类排序在数据库最后 。
4) 所有的冗余类的命名(主要是累计表)前面加上前缀X
冗余类是为了提高数据库效率,非规范化数据库的时候加入的字段或者表
5) 关联类通过用下划线连接两个基本类之后,再加前缀R的方式命名,后面按照字母顺序罗列两个表名或者表名的缩写 。
关联表用于保存多对多关系 。
如果被关联的表名大于10个字母,必须将原来的表名的进行缩写 。如果没有其他原因,建议都使用缩写 。
举例:表Object与自身存在多对多的关系,则保存多对多关系的表命名为:R_Object;
表 Depart和Employee;存在多对多的关系;则关联表命名为R_Dept_Emp
2. 属性(列)的命名
1) 采用有意义的列名,表内的列要针对键采用一整套设计规则 。每一个表都将有一个自动ID作为主健,逻辑上的主健作为第一组候选主健来定义,如果是数据库自动生成的编码,统一命名为:ID;如果是自定义的逻辑上的编码则用缩写加“ID”的方法命名 。如果键是数字类型,你可以用_NO 作为后缀;如果是字符类型则可以采用_CODE 后缀 。对列名应该采用标准的前缀和后缀 。
举例:销售订单的编号字段命名:Sal_Ord_ID;如果还存在一个数据库生成的自动编号,则命名为:ID 。
2) 所有的属性加上有关类型的后缀,注意 , 如果还需要其它的后缀,都放在类型后缀之前 。
注: 数据类型是文本的字段,类型后缀TX可以不写 。有些类型比较明显的字段 , 可以不写类型后缀 。
3) 采用前缀命名
给每个表的列名都采用统一的前缀,那么在编写SQL表达式的时候会得到大大的简化 。这样做也确实有缺点,比如破坏了自动表连接工具的作用,后者把公共列名同某些数据库联系起来 。
3. 视图的命名
1) 视图以V作为前缀,其他命名规则和表的命名类似;
2) 命名应尽量体现各视图的功能 。
4. 触发器的命名
触发器以TR作为前缀,触发器名为相应的表名加上后缀,Insert触发器加'_I',Delete触发器加'_D',Update触发器加'_U',如:TR_Customer_I , TR_Customer_D,TR_Customer_U 。
5. 存储过程名
存储过程应以'UP_'开头 , 和系统的存储过程区分,后续部分主要以动宾形式构成,并用下划线分割各个组成部分 。如增加代理商的帐户的存储过程为'UP_Ins_Agent_Account' 。
6. 变量名
变量名采用小写 , 若属于词组形式,用下划线分隔每个单词,如@my_err_no 。
7. 命名中其他注意事项
1)以上命名都不得超过30个字符的系统限制 。变量名的长度限制为29(不包括标识字符@) 。
2)数据对象、变量的命名都采用英文字符,禁止使用中文命名 。绝对不要在对象名的字符之间留空格 。
3) 小心保留词,要保证你的字段名没有和保留词、数据库系统或者常用访问方法冲突
5) 保持字段名和类型的一致性,在命名字段并为其指定数据类型的时候一定要保证一致性 。假如数据类型在一个表里是整数,那在另一个表里可就别变成字符型了 。
求PHP全套教程《细说php》php3数据字典教程,LAMP兄弟连php3数据字典教程的php3数据字典教程,极力推荐php3数据字典教程?。。〖负鹾撬械膒hp知识点 , 我快把整本书都翻烂了 。尤其推荐韩顺平老师讲的php课程,通俗易懂,诙谐幽默,自学php两年多了,可以说php3数据字典教程他是我的启蒙老师 。可以在网上搜索“韩顺平php视频教程”,记得好评哦亲 。
PHP入门基础教程 PHP入门基础教程大全
PHP于1994年由Rasmus Lerdorf创建php3数据字典教程,刚刚开始是Rasmus Lerdorf为了要维护个人网页而制作php3数据字典教程的一个简单的用Perl语言编写的程序 。这些工具程序用来显示 Rasmus Lerdorf 的个人履历 , 以及统计网页流量 。后来又用C语言重新编写,包括可以访问数据库 。他将这些程序和一些表单直译器整合起来,称为 PHP/FI 。PHP/FI 可以和数据库连接,产生简单的动态网页程序 。为帮助大家入门学习php,我为大家分享PHP入门知识教程如下:
1、嵌入方法:
类似ASP的%,PHP可以是?php或者是?,结束符号是?,当然您也可以自己指定 。
2、引用文件:
引用文件的方法有两种:require 及 include 。
require 的使用方法如 require("MyRequireFile.php");。这个函数通常放在 PHP 程序的最前面,PHP 程序在执行前,就会先读入 require 所指定引入的文件,使它变成 PHP 程序网页的一部份 。常用的函数,亦可以这个方法将它引入网页中 。
include 使用方法如 include("MyIncludeFile.php");。这个函数一般是放在流程控制的处理部分中 。PHP 程序网页在读到 include 的文件时,才将它读进来 。这种方式,可以把程序执行时的流程简单化 。
3、注释方法:
?php
echo "这是第一种例子 。\n" ; // 本例是 C语法的注释 (PHP的注释跟C差不多?。?
/* 本例采用多行的
注释方式 */
echo "这是第二种例子 。\n" ;
echo "这是第三种例子 。\n" ; # 本例使用 UNIX Shell 语法注释
?
4、变量类型:
$mystring = "我是字符串" ;
$NewLine = "换行了\n" ;
$int1 = 38 ;
$float1 = 1.732 ;
$float2 = 1.4E 2 ;
$MyArray1 = array( "子" , "丑" , "寅" , "卯" );
这里引出两个问题,首先PHP变量以$开头,第二PHP语句以;结尾,可能ASP程序员会不适应 。这两个遗漏也是程序上大多错误所在 。
5、运算符号:
数**非法字眼已被屏蔽**算:
符号意义
加法运算
-减法运算
*乘法运算
/除法运算
%取余数
累加
--递减
字符串运算:
运算符号只有一个,就是英文的句号 。它可以将字符串连接起来,变成合并的新字符串 。类似ASP中的
?
$a = "PHP 4" ;
$b = "功能强大" ;
echo $a.$b;
?
这里也引出两个问题,首先PHP中输出语句是echo , 第二类似ASP中的%=变量%,PHP中也可以?=变量? 。
逻辑运算:
符号 意义
小于
大于
= 小于或等于
= 大于或等于
== 等于
!= 不等于
而且 (And)
and 而且 (And)
或者 (Or)
or 或者 (Or)
xor 异或 (Xor)
! 不 (Not)
学习目的:掌握php的流程控制
1、if..else 循环有三种结构
第一种是只有用到 if 条件,当作单纯的判断 。解释成 "若发生了某事则怎样处理" 。语法如下:
if (expr) { statement }
其中的 expr 为判断的条件,通常都是用逻辑运算符号当判断的条件 。而 statement 为符合条件的执行部分程序,若程序只有一行 , 可以省略大括号 {} 。
范例:本例省略大括号 。
?php
if ($state==1)echo "哈哈" ;
?
这里特别注意的是,判断是否相等是==而不是= , ASP程序员可能常犯这个错误 , = 是赋值 。
范例:本例的执行部分有三行,不可省略大括号 。
?php
if ($state==1) {
echo "哈哈 ;
echo "br" ;
}
?
第两种是除了 if 之外,加上了 else 的条件,可解释成 "若发生了某事则怎样处理,否则该如何解决" 。语法如下
if (expr) { statement1 } else { statement2 } 范例:上面的例子来修改成更完整的处理 。其中的 else 由于只有一行执行的指令,因此不用加上大括号 。
?php
if ($state==1) {
echo "哈哈" ;
echo "br";
}
else{
echo "呵呵";
echo "br";
}
?
第三种就是递归的 if..else 循环,通常用在多种决策判断时 。它将数个 if..else 拿来合并运用处理 。
直接看下面的例子
?php
if ( $a$b ) {
echo "a 比 b 大" ;
} elseif ( $a == $b ) {
echo "a 等于 b" ;
} else {
echo "a 比 b 小" ;
}
?
上例只用二层的 if..else 循环,用来比较 a 和 b 两个变量 。实际要使用这种递归 if..else 循环时,请小心使用,因为太多层的循环容易使设计的逻辑出问题,或者少打了大括号等,都会造成程序出现莫名其妙的问题 。
2、 for 循环就单纯只有一种,没有变化,它的语法如下
for (expr1; expr2; expr3) { statement }
其中的 expr1 为条件的`初始值 。expr2 为判断的条件,通常都是用逻辑运算符号 (logical operators) 当判断的条件 。expr3 为执行 statement 后要执行的部份,用来改变条件,供下次的循环判断,如加一..等等 。而 statement 为符合条件的执行部分程序,若程序只有一行,可以省略大括号 {} 。
下例是用 for 循环写的的例子 。
?php
for ( $i = 1 ; $i = 10 ; $i) {
echo "这是第".$i."次循环br" ;
}
?
3、 switch 循环,通常处理复合式的条件判断,每个子条件,都是 case 指令部分 。在实作上若使用许多类似的 if 指令,可以将它综合成 switch 循环 。
语法如下
switch (expr) { case expr1: statement1; break; case expr2: statement2; break; default: statementN; break; }
其中的 expr 条件,通常为变量名称 。而 case 后的 exprN,通常表示变量值 。冒号后则为符合该条件要执行的部分 。注意要用 break 跳离循环 。
?php
switch ( date ( "D" )) {
case "Mon" :
echo "今天星期一" ;
break;
case "Tue" :
echo "今天星期二" ;
break;
case "Wed" :
echo "今天星期三" ;
break;
case "Thu" :
echo "今天星期四" ;
break;
case "Fri" :
echo "今天星期五" ;
break;
default:
echo "今天放假" ;
break;
}
?
这里需要注意的是break;别遗漏了 , default,省略是可以的 。
很明显的,上述的例子用 if 循环就很麻烦了 。当然在设计时,要将出现机率最大的条件放在最前面,最少出现的条件放在最后面,可以增加程序的执行效率 。上例由于每天出现的机率相同,所以不用注意条件的顺序 。
学会构建数据库
在PHP中,MY SQL的命令行编辑可能会令初学者感到很麻烦,不要紧 , 你下载一个PHPMYADMIN安装一下,以后建立编辑数据库可以靠它了 。
下面说一下它的使用 。
进入了phpmyadmin后,我们首先需要建立一个数据库,
Language (*) 这里选择中文简体,然后在左边的 创建一个新的数据库 这里填写数据库名字,点击创建即可 。
然后在左边下拉菜单中选择那个已经创建的数据库 。在下面的
在数据库 shop 中创建一个新表 :
名字 :
字段数 :
中填写表名字和大致你认为的字段数(不够或者多了都不要紧,以后可以再添加或者缺?。? ,按执行 。
然后就可以开始建立表了 。
第一栏是字段的名字;第二栏选择字段类型:
我们常用的是以下几个:
1)VARCHAR,文本类型
2)INT,整数类型
3)FLOAT,浮点数类型
4)DATE,日期型
5)大家或许会问,自动添加的ID在哪里?这个只要选择INT类型 , 在后面的额外中选择 auto_increment 就可以了 。
建立了表以后,可以在左边看到你建立的表,点击以后,你可以:
1)按右边的结构:查看修改表结构
2)按右边的浏览:查看表中的数据
3)按右边的SQL:运行SQL语句
4)按右边的插入:插入一行记录
5)按右边的清空:删除表中所有记录
6)按右边的删除:删除表
还有一个很重要的功能就是导入和导出,当我们本机做好了程序和数据库的时候,需要在服务器上也有一个本地镜像 , 如果是ASP的ACCESS简单了 , 直接上传MDB文件即可,如果是SQL SERVER也可以连接远端服务器进行导入 。那么MY SQL中你可以导出所有的SQL语句,到了远端服务器的PHPMYADMIN上 , 创建数据库后按SQL,粘帖你刚才复制下来的所有本级生成的SQL语句即可 。
学会连接数据库
PHP简直就是一个函数库 , 丰富的函数使PHP的某些地方相当简单 。建议大家down一本PHP的函数手册,总用的到 。
我这里就简单说一下连接MYSQL数据库 。
1、mysql_connect
打开 MySQL 服务器连接 。
语法: int mysql_connect(string [hostname] [:port], string [username], string [password]); 返回值: 整数
本函数建立与 MySQL 服务器的连接 。其中所有的参数都可省略 。当使用本函数却不加任何参数时,参数 hostname 的默认值为 localhost、参数 username 的默认值为 PHP 执行行程的拥有者、参数 password 则为空字符串 (即没有密码) 。而参数 hostname 后面可以加冒号与端口号,代表使用哪个端口与 MySQL 连接 。当然在使用数据库时 , 早点使用 mysql_close() 将连接关掉可以节省资源 。
2、 mysql_select_db
选择一个数据库 。
语法: int mysql_select_db(string database_name, int [link_identifier]); 返回值: 整数
本函数选择 MySQL 服务器中的数据库以供之后的资料查询作业 (query) 处理 。成功返回 true,失败则返回 false 。
最简单的例子就是:
$conn=mysql_connect ("127.0.0.1", "", "");
mysql_select_db("shop");
连接机MY SQL数据库,打开SHOP数据库 。在实际应用中应当加强点错误判断 。
学会读取数据
先看两个函数:
1、mysql_query
送出一个 query 字符串 。语法: int mysql_query(string query, int [link_identifier]); 返回值: 整数
本函数送出 query 字符串供 MySQL 做相关的处理或者执行 。若没有指定 link_identifier 参数,则程序会自动寻找最近打开的 ID 。当 query 查询字符串是 UPDATE、INSERT 及 DELETE 时,返回的可能是 true 或者 false;查询的字符串是 SELECT 则返回新的 ID 值,当返回 false 时,并不是执行成功但无返回值,而是查询的字符串有错误 。
2、mysql_fetch_object 返回类资料 。语法: object mysql_fetch_object(int result, int [result_typ]); 返回值: 类
本函数用来将查询结果 result 拆到类变量中 。若 result 没有资料 , 则返回 false 值 。
看一个简单的例子:
?
$exec="select * from user";
$result=mysql_query($exec);
while($rs=mysql_fetch_object($result))
{
echo "username:".$rs-username."br";
}
?
当然 , 表user中有一个username的字段,这就类似asp中的
%
exec="select * from user"
set rs=server.createobject("adodb.recordset")
rs.open exec,conn,1,1
do while not rs.eof
response.write "username:"rs("username")"br"
rs.movenext
loop
%
当然先要连接数据库,一般我们 require_once('conn.php');而conn.php里面就是上一次说的连接数据库的代码 。
小小的两条命令可以完成读取数据的工作了
学会添加删除修改数据
mysql_query($exec);
单这个语句就可以执行所有的操作了 , 不同的就是$exec这个sql语句
添加:$exec="insert into tablename (item1,item2) values ('".$_POST['item1']."',".$_POST['item1'].")";
删除:$exec="delete from tablename where...";
修改:$exec="update tablename set item1='".$_POST['item1']."' where ...";
说到这里就要说一下表单和php变量传递,如果表单中的一个 input name="item1" type="text" id="item1"
表单以POST提交的,那么处理表单文件就可以用$_POST['item1']得到变量值 , 同样以GET提交的就是$_GET['item1']
是不是很简单?但是通常$exec会有问题,因为可能您的SQL语句会很长 , 您会遗漏.连接符,或者'来包围字符型字段 。
我们可以注释mysql_query($exec);语句用echo $exec;代替来输出$exec以检查正确性 。如果您还不能察觉$exec有什么错误的话,可以复制这个sql语句到phpmyadmin中执行,看看它的出错信息 。还有需要注意的是,我们不要使用一些敏感的字符串作为字段名字,否则很可能会出现问题,比如说date什么的 。变量的命名 , 字段的命名遵循一点规律有的时候对自己是一种好处,初学者并不可忽视其重要性 。
学会SESSION的使用
SESSION的作用很多,最多用的就是站点内页面间变量传递 。
在页面开始我们要session_start();开启SESSION;
然后就可以使用SESSION变量了 , 比如说要赋值就是:$_SESSION['item']="item1";要得到值就是$item1=$_SESSION['item'];,很简单吧 。这里我们可能会使用到一些函数,比如说判断是不是某SESSION变量为空,可以这么写:empty($_SESSION['inum'])返回true or false 。
下面综合一下前面所说的我们来看一个登陆程序,判断用户名密码是否正确 。
登陆表单是这样:login.php
table width="100%" height="100%" border="0" align="center" cellpadding="0" cellspacing="0"
tr
form action="checklogin.php" method="post"td align="center" valign="middle"table width="400" border="0" cellpadding="5" cellspacing="1" class="tablebg"
tr class="tdbg"
td colspan="2"p align="center"Administrators Login/p/td
/tr
tr class="tdbg"
tdp align="center"Username/p/td
tdp align="center"
input name="username" type="text" id="username"
/p/td
/tr
tr class="tdbg"
tdp align="center"Password/p/td
tdp align="center"
input name="password" type="password" id="password"
/p/td
/tr
tr class="tdbg"
td colspan="2"p align="center"
input type="submit" name="Submit" value="https://www.04ip.com/post/Submit"
input type="reset" name="Submit2" value="https://www.04ip.com/post/Clear"
/p/td
/tr
/table/td/form
/tr
/table
处理文件是这样
?php
require_once('conn.php');
session_start();
$username=$_POST['username'];
$password=$_POST['password'];
$exec="select * from admin where username='".$username."'";
if($result=mysql_query($exec))
{
if($rs=mysql_fetch_object($result))
{
if($rs-password==$password)
{
$_SESSION['adminname']=$username;
header("location:index.php");
}
else
{
echo "scriptalert('Password Check Error!');location.href='https://www.04ip.com/post/login.php';/script";
}
}
else
{
echo "scriptalert('Username Check Error!');location.href='https://www.04ip.com/post/login.php';/script";
}
}
else
{
echo "scriptalert('Database Connection Error!');location.href='https://www.04ip.com/post/login.php';/script";
}
?
conn.php是这样:
?php
$conn=mysql_connect ("127.0.0.1", "", "");
mysql_select_db("shop");
?
由于 $_SESSION['adminname']=$username;我们可以这样写验证是否登陆语句的文件:checkadmin.php
?php
session_start();
if($_SESSION['adminname']=='')
{
echo "scriptalert('Please Login First');location.href='https://www.04ip.com/post/login.php';/script";
}
?
做一个分页显示
关键就是用到了SQL语句中的limit来限定显示的记录从几到几 。我们需要一个记录当前页的变量$page , 还需要总共的记录数$num
对于$page如果没有我们就让它=0 , 如果有0就让它也=0 , 如果超过了总的页数就让他=总的页数 。
$execc="select count(*) from tablename ";
$resultc=mysql_query($execc);
$rsc=mysql_fetch_array($resultc);
$num=$rsc[0];
这样可以得到记录总数
ceil($num/10))如果一页10记录的话,这个就是总的页数
所以可以这么写
if(empty($_GET['page']))
{
$page=0;
}
else
{
$page=$_GET['page'];
if($page0)$page=0;
if($page=ceil($num/10))$page=ceil($num/10)-1;//因为page是从0开始的,所以要-1
}
这样$exec可以这么写 $exec="select * from tablename limit ".($page*10).",10";
//一页是10记录的
最后我们需要做的就是几个连接:
a href="https://www.04ip.com/post/xxx.php?page=0"FirstPage/a
a href="https://www.04ip.com/post/xxx.php?page=?=($page-1)?"PrevPage/a
a href="https://www.04ip.com/post/xxx.php?page=?=($page 1)?"NextPage/a
a href="https://www.04ip.com/post/xxx.php?page=?=ceil($num/10)-1?"LastPage/a
注意事项
1、注意不要漏了分号
2、注意不要漏了变量前的$
3、使用SESSION的时候注意不要遗漏session_start();
如果发生错误的时候,可以采用以下方法:
1、如果是SQL语句出错,就注释了然后输出SQL语句,注意也要注释调后续的执行SQL语句
2、如果是变量为空 , 大多是没有传递到位,输出变量检查一下,检查一下表单的id和name
3、如果是数据库连接出错,检查是否正确打开MY SQL和是否遗漏了连接语句
4、注意缩进,排除括号不区配的错误
在做大网站的时候,我的思路是先构建数据库,确定每一个字段的作用,和表之间的关系 。然后设计后台界面,从添加数据开始做起,因为添加是否成功可以直接到数据库里面验证,做好了添加再做显示的页面,最后才是两者的结合 。一般来说后台就包括添加删除修改和显示,后台没有问题了,前台也没有什么大问题 。前台还需要注意安全性和容错还有就是输出格式 。
学会用PHP上传文件和发邮件
上传文件表单必须加上 enctype="multipart/form-data"
和 input type="file" name="file"
下面看一下代码:
$f=$HTTP_POST_FILES['file'];
$dest_dir='uploads';//设定上传目录
$dest=$dest_dir.'/'.date("ymd")."_".$f['name'];//我这里设置文件名为日期加上文件名避免重复
$r=move_uploaded_file($f['tmp_name'],$dest);
chmod($dest, 0755);//设定上传的文件的属性
上传的文件名为date("ymd")."_".$f['name'] ,可以在以后插入到数据库的时候用到,PHP实际上是把你上传的文件从临时目录移动到指定目录 。move_uploaded_file($f['tmp_name'],$dest);这是关键
至于发邮件就更加简单 , 可以使用mail()函数
mail("收件人地址","主题","正文","From:发件人\r\nReply-to:发件人的地址");
不过mail()需要服务器的支持,在WINDOWS下还需要配置SMTP服务器,一般来说外面的LINUX空间都行 。
好像上传文件和发邮件比ASP简单很多,只要调用函数就可以了 。ASP还需要用到服务器的不同组件比如FSO、JMAIL什么的 。
;
php语言字典代码求一PHP算法,字典生成 。时间一到再加100分 。如:字符:0-9 , 长度:1,
那就生成0,1,2,3,4,5,6,7,8,9
长度:2,就会生成00-99
现在要求字符可以包括a-z,或者其他特殊符号,求一高效的生成算法 。
参考答案一
function get_string($strlen){
$source='0123456789'; //任意字符
$len = strlen($source); //长度
$return = array();
for($i = 0 ;$i$len;$i){
for($j = 0;$j$strlen;$j){
$return[$i] .= $i;
}
}
return implode(',', $return);
}
如果输入长度2: 输出结果就是:
00,11,22,33,44,55,66,77,88,99
参考答案二
优化了进位算法:
PHP code =0;$no--){ $word=$source{$series[$no]}.$word; $series[$no] =$tonext_value; if($no0){ if($series[$no]==$len){ $series[$no]=0; $tonext_value=https://www.04ip.com/post/1; }else{ $tonext_value=0; } } } echo"$word "; } } gene_dic(2); ?
简单的说,我会把这个理解为0-9(十进制)下十个数字生成两位数字、可重复的排列问题 。
排列算法我自己建立过的就是简单的N进制下的 1算法,保证可以遍历 。
即:
初始化到0,
1.1
2. 是否超过要生成的位数?否,则回到1;
3. 输出
参考答案三
PHP code =0;$no--){//循环遍历数组每次从源字串中取一个字符,为便于进位运算 , 取字符是从后往前取 $word=$source{$series[$no]}.$word;//先取出一个字符 //取出一个字符后就要判断当前数组元素如何如果改变值,为下一次“大循环”做准备 if($no==$n-1){//末位的判断 , 它比较特殊,每次大循环都要增值 if($series[$no]==$len-1){ $series[$no]=0; $tonext_value=https://www.04ip.com/post/1;//归零时就进位 }else{ $series[$no] =1; $tonext_value=0;//未归零就增值,不进位 } }elseif($no$n-1){//中间位的进位判断 $series[$no] =$tonext_value;//先取得上一位的进位值 if($series[$no]==$len){ $series[$no]=0; $tonext_value=1;//归零了就继续进位 }else{ $tonext_value=0;//不归零就不进位 } }else{ $series[$no] =$tonext_value;//大循环次数决定了“老大”是只进不出的 。} } echo"$word ";//输入单词 } } gene_dic(2);//测试,结果OK 。
参考答案四
PHP code =0;$no--){//循环遍历数组每次从源字串中取一个字符,为便于进位运算,取字符是从后往前取 $word=$source{$series[$no]}.$word;//先取出一个字符 //取出一个字符后就要判断当前数组元素如何如果改变值,为下一次“大循环”做准备 if($no==$n-1){//末位的判断,它比较特殊,每次大循环都要增值 if($series[$no]==$len-1){ $series[$no]=0; $tonext_value=https://www.04ip.com/post/1;//归零时就进位 }else{ $series[$no] =1; $tonext_value=0;//未归零就增值,不进位 } }elseif($no$n-1){//中间位的进位判断 $series[$no] =$tonext_value;//先取得上一位的进位值 if($series[$no]==$len){ $series[$no]=0; $tonext_value=1;//归零了就继续进位 }else{ $tonext_value=0;//不归零就不进位 } }else{ $series[$no] =$tonext_value;//大循环次数决定了“老大”是只进不出的 。} } echo"$word ";//输入单词 } } gene_dic(2);//测试,结果OK 。
参考答案五
应该是:
function get_string($strlen){
$source='0123456789';
$len = strlen($source);
$return = array();
for($i = 0 ;$i$len;$i){
for($j = 1;$j = $strlen;$j){
$return[$i] .= substr($source,$i,1);
}
}
return implode(',', $return);
}
【拓展阅读】如何开始一门语言的学习
一门语言从发明到演进必有原因 。
现在还有很多人推荐学习不同的语言 。通过比较,了解它的发展史 ,
创始人的初心等因素都需要留意 。多个思考,这个语言在5年,在10年后还是否保持活力?
当有几个类似的语言被选择时,我们不妨对它们做一个Swat分析 。
列出这些语言的共同点 , 还有它们之间的规则差异 。
了解语言的发展史
开发语言从汇编开始,如最早的计算机ENIAC,使用的就是它来编程 。
再到Fortarin,再到C语言 , Cobol,Basic 。每一个语言都与当时发展的阶段有点密切关联 。
人类的每个发明都与懒惰有关 , 语言也是为便捷性而生 。有的语言
C是除汇编外最重视效率的语言,扩展的C也继承了此特性 。Perl是做文本处理效率最佳的语言,虽然它的发展有点慢 。PHP做Web开发,是“世界上最好的.语言”,Python的阅读性和大数据处理都做得样样俱佳 。
当了解语言的历史沿革后,会让我们对其创始人有很强烈的兴趣,成为忠实的脑残粉,学习该语言的兴趣会更浓烈 。
人们常常说某个语言比哪个好,这其实没有必要 。不必要为其它人的语言所惑,需要你自己做出选择 。
语言的共通点
这个星球的人都是一个鼻子两双只水汪汪的大眼睛,与人们的模样一般,编程语言也有一个大致相同的长相 。
语法:这是开发此语言定义的规则“套路”:
运算符顺序,变量常量定义/作用域,表达式定义,字符串定义,行尾结束符等 。
流程控制:循环控制
这些语法都是成对的,如if,for,while,foreach,有的语言还提供goto这样类似汇编语言的语法 。
函数与方法
一些能够复用的高质量代码组合 。函数执行后有返回 , 有递归 , 有嵌套,还有干完活就完事的简单任务 。有静态函数和动态函数区分 。
容器
数组,哈希表(也叫散列),字典等用来保存数据的容器 。
错误/例外处理
现代编程语言基本都支持出错的抛出,除了C语言之外 。
比如硬盘不足 , 网络出错,黑客攻击等情形 。就像购物中心里出现煤气泄露时,监测设备,物联网设备能够及时记录与传递给指挥中心 。
没有错误抛出的语言 , 需要自己考虑尽可能出错的场景并处理,比如:
if(is_overfllow)
//处理
if(network_error)
//处理
可以还有不少需要关注的维度 , 这会让代码变得艰涩难懂,也难以维护 。
我们可以用这样的方式,让其更简洁:
on error goto ERROR
ERROR:
..//
但这总是会需要我们照顾很多情形 。于是C推出了一个语法:
try{
//可能会出错的代码
//可能会出错的代码
}catch{
//处理出错的逻辑
//处理出错的逻辑
}finally{
//出不出错都要执行的代码
}
最后一句是微软公司给业界提供贡献的finally代码块 。
以上这些成为语言处理异常机制的基础 。
容器
容器是很重要的一节,所以我们单独再提出来 。很多逻辑处理 , 使用容器保存数据,该语言会提供便捷的方法来提供存取 。
比如C、Perl、PHP、Ruby中均提供的数组和关联数组,LISP提供的列表,Java、Python提供的元组、链表等 。
虽然名字相同 , 但是实现方式却是完全不同,使用方法当然也不一样 。
没有万能的容器,只有最合适的 。可以从节省内存,节约时间还是编码效率等综合考虑 。
字符串与字符编码
是否支持unicode编码 。从摩斯码到ASCII到统一的Unicode编码支持 。
并发处理
有的语言在设计时并无此方面的考虑,或者天生设计存在缺陷 。
即多线程,多进程的概念 。包括共享,锁,事备等特性 。
面向对象
支持类,继承 , 模块,包,命名空间,闭包等 。有这些特性才会让人们的工作变得更便利、更有效率 。
小结
学习一门语言的关键 , 需要我们在平静地心绪下,带着浓厚的兴趣去学习,在比较中学习,在历史中学习 。
有时候感觉还是不够通畅,先做知识的搬运工也是不错 。另外 , 不断的实践会让我们的信心更足 。
求一点PHP对TXT文件和文章的操作教程PHP教程.安装PHP
安装PHP
本章将按下列步骤编译安装以下软件:
* Apache v.1.3.4 -- 世界上最流行php3数据字典教程的Web服务器 。
* gcc v.2.8.1 -- 来源于GNU的C和C编译器 。
* MySQL v.3.22.16b-gamma -- 世界范围内许多人使用的数据库 。
* PHP v.3.0.11 -- 本书所主要介绍的软件 。从(或此站点的镜象站点)直接下载可以得到较新的版本 。本章的其它步骤仍然适用 。
* expact -- 用于读取和处理XML文档的函数库 。
* phplib -- 用于进行会话管理的PHP函数库 。
* libiodbc -- 主要用于存取在非UNIX计算机中数据库的ODBC函数库 。
* MyODBC -- PHP、iODBC和MySQL之间的函数库 。
即便如此php3数据字典教程,本章也并不是介绍编译应用程序所需要的那些指令,而只是简单的进行描述 。总之,本书的重点是介绍PHP语言 , 而不是C语言 。每一个应用程序的编译对php3数据字典教程我来说都十分清楚,希望每个读者也能没有困难的进行编译 。假如php3数据字典教程你确实碰到了一些问题,可以在某个IRC频道中有礼貌的询问,或者可以尝试使用新闻组(可以从访问)得到帮助来解决问题 。然而 , 最好的帮助还是来自 上的PHP邮件列表 。
在开始编译过程之前,让我们先讨论一下如何从错误中恢复 。在得到有关错误的帮助以后 , 可以采用以下的命令重新初始化源码目录:
* rm config.cache--几乎所有的Linux应用程序都使用configure命令来检查自己的系统 , 以寻找有关如何剪裁编译过程的信息 。检查的结果将存贮在一个名为config.cache的文件中 。如果移走此文件,将迫使配置程序从头开始重新检查系统 。
* make distclean--所有的用C语言编写的Linux应用程序都是用make程序编译的 。make程序会寻找每一个源文件,以确认是需要编译还是已经编译过的 。make distclean命令可以“重置”所有的源程序,以便能重新编译它们 。
* make clean--有的应用程序不支持make distclean命令,而用make clean命令来代替 。make clean命令“重置”所有的源程序,以便能重新编译它们 。
即使要安装的一些应用程序不支持以上的每个命令,但是试一下这些命令也不会有什么害处 。
注意:Red Hat v5.2使用glibc库 。如果用户从互联网中下载或更新在本章中安装的程序时,必须知道glibc的信息 。使用者可以使用rpm -q glibc命令来查出已经安装的glibc库的版本号 。在作者的系统中,使用rpm -q glibc命令将显示glibc-2.0.7.29 。
2.1 基本概念
也许读者以前从没有编译过Linux应用程序,在这里介绍一些基本概念,以便在出现问题时有可能诊断出问题所在 。
tar
tar,即tape archiver,它可以把几个文件组合成一个文件,并可以选择是否进行压缩 。这个命令过去通常用来进行备份,以便使数据存储在磁带中 。当tar文件被压缩时,它们有一个.gz的后缀php3数据字典教程;当tar文件没有压缩时,它们有一个.tar的后缀 。
gcc
gcc 是GNU的C编译器 。它的工作是把人可以看懂的源代码文件编译成机器可以读懂的目标文件 。C源文件通常有.c的后缀名 , 目标文件通常有.o的后缀名 。如果编译工作不能正常进行,就是碰到了一个编译期的错误,或者说:语法错误 。在大多数情况下 , 不彻底的编译通常是编译器找不到一个或几个包含文件而产生的 。包含文件都有一个.h的扩展名,通常用来定义不同的系统信息,以及将多个不同的.c文件所共有的信息收集在一起 。
make
make是一个常用的工具程序,是用来帮助进行编译的 。它的工作是用来只编译那些还没有编译过的源文件 。编译.c文件将生成一个.o文件,如果.c文件比.o文件更新,也就是说到上次编译之前,源文件被编辑过,那么make将会重新编译.c文件 。make指令一般是寻找一个Makefile文件,在这个文件中包含有一个或多个能执行的目标,例如,make clean会告诉make执行清除目标 。
ld
ld是GNU的链接程序 。它的工作是把所有的目标文件和库链接起来,创建一个单一的可执行文件 。幸运的是,基本上不用手工运行这个程序,因为Makefile将会考虑到所有的编译细节 。
ldconfig
ldconfig会为在多个库目录(在/etc/ld.so.conf中指定)中寻找共享库 。共享库常被多个的应用程序使用 , 它们的文件名中的某个地方有.so , 例如,libqt.so.1.42是一个共享库 。在编译完毕之后,有可能需要在/etc/ld.so.conf文件中增加一个目录,并且运行ldconfig -v命令 。
./configure
configure将会在计算机中寻找一些关键信息,例如,安装的是哪一种C编译器,包含文件在哪里等等 。然后,configure将会按照所用的计算机配置重新修改Makefile文件 。应该使用./configure来在当前目录下运行程序,以避免偶然运行$PATH环境变量中的目录下的其他程序 。
符号连接
符号连接允许使用者可以为一个已经现有的文件指定另一个不同的名字 。例如,使用者有可能想把一个名为libqt.so.1.42的文件称为libqt.so.1 。符号连接基本上可以使用户把一个文件复制到另一个不同的目录下面,但事实上并没有真正复制此文件 。第二个文件实例只是简单地指向第一个文件实例 。使用符号连接至少可以有两点好处,第一点是符号连接可以节省硬盘空间,少到只有16字节;第二点有一点微妙,让我们先看一下一个名为libqt.so.1且指向libqt.so.1.42的符号连接 。如果需要升级到libqt.so.1.88,该怎么办呢?用户只要简单地改变符号连接,使libqt.so.1指向libqt.so.1.88,而非libqt.so.1.42即可 。这意味着涉及到libqt.so.1的程序将自动地使用这个库的新版本 。按照惯例,符号连接常用于完整的发布版本号 。换句话说,libqt.so.1.88和libqt.so.2.32应该有两个不同的动态连接(分别为libqt.so.1和libqt.so.2) 。
2.2 编译前的准备工作
以下步骤将为系统做好编译前的准备工作 。
1. mkdir /usr/local/src -- 我选用/usr/local树作为所安装应用程序的根目录 。其他人可能选用/usr/opt、/opt或/var目录 。为了更方便的按照本章中的指令操作,请选用/usr/local目录作为根目录 。当编译完成以后,用户可以把这些文件复制到不同的目录中 。
注意:为了能完成本章中的其它步骤,使用者必须具备root权限 。
2. cd /usr/local/src--转到源文件目录下 。
3. 下载以下文件(可以从站点下载),或者从本书随机附带的光盘中,复制这些文件到/usr/local/src目录下:
. apache_1.3.4.tar.gz
. gcc-2.8.1.tar.gz
. mysql-3.22.16b-gamma.tar.gz
. php-3.0.11.tar.gz
. expat.tar.gz
. phplib.tar.gz
. libiodb-2.50.3
. myodbc-2.50.24-src
4. 使用tar命令解压缩以上文件 。tar的x选项为解开选项 , v选项将在屏幕上显示文档中解出来的文件名,z选项为解压缩选项,f选项用于在命令行中指定.tar文件名 。
tar xvzf apache_1.3.4.tar.gz
tar xvzf gcc-2.8.1.tar.gz
tar xvzf mysql-3.22.16b-gamma.tar.gz
tar xvzf php-3.0.11.tar.gz
tar xvzf expat.tar.gz
tar xvzf phplib.tar.gz
5. gcc -v
确定系统中现有gcc的版本 。如果你的系统不是v2.7.2.3,在下面的操作步骤中采用你的gcc版本号替换v.2.7.2.3 。
6. cp `which gcc` /usr/bin/gcc-2.7.2.3
如果需要,把现有的gcc备份,以便以后使用 。Linux的另一个优点是可以很容易在目录下存储一个程序的多个版本 。
7. httpd -v
确定系统中的Apache的版本号 。如果你的系统中的Apache不是v1.3.4,在下面的操作步骤中使用你的版本号替换v1.3.4 。
8. mv `which httpd` /usr/sbin/httpd-1.3.4
如果需要 , 把现有的Apache备份,以便以后使用 。
2.3 编译C编译器gcc
使用者应该安装、编译程序的第一个程序就是C编译器 。随Red Hat v5.2附带的C编译器是gcc v2.7.2.3,由于它的版本比较低,以至于不能正确的编译PHP 。然而gcc v.2.7.3可以用来编译版本较高的gcc v2.8.1 。
编译新版本的gcc需要执行:
1. cd /usr/local/src/gcc-2.8.1
转到gcc的顶级目录下 。
2. ./configure -prefix=/usr/local/gcc
运行配置程序,强制安装程序在后面的安装过程中使用/usr/local/gcc作为gcc的安装目录 。
3. make bootstrap LANGUAGES="c c" BOOT_CFLAGS="-g -02"
编译新的C和C编译器 。
4. make install LANGUAGES="c c" BOOT_CFLAGS="-g -02"
安装新的C和C编译器 。
5. mv /usr/local/gcc/bin/gcc /usr/local/gcc/bin/gcc-2.8.1
把新的gcc编译器重新命名,使它的名字中含有版本号 。
6. ln -s \
/usr/local/gcc/bin/gcc-2.8.1 \
/usr/bin/gcc-
给新编译过的gcc可执行文件创建一个符号连接/usr/bin/gcc 。
7. gcc -v
显示gcc的版本号 。如果编译和安装都正常的话,将显示v.2.8.1 。
2.3 编译MySQL
现在来编译MySQL 。在编译工作完成之后,就可以使用MySQL的应用程序来测试安装 。
1. cd /usr/src/mysql-3.22.16a-gamma
转到MySQL的顶级目录下 。
2. ./configure --prefix=/usr/local/mysql
运行配置程序,强制安装程序在后面的安装过程中使用/usr/local/mysql作为MySQL的安装目录 。
3. make
编译MySQL 。
4. make install
安装MySQL 。
5. echo "/usr/local/mysql/lib/mysql"/etc/ld.so.conf
将MySQL库所在的目录添加进配置文件中 。这样 , 当Linux启动或者执行ldconfig命令时,将会在该配置文件中的目录里搜索库文件 。
6. ldconfig -v | grep libmysqlclient
ldconfig命令能读取/etc/ld.so.conf文件中列出的目录 , 并对在那些目录里找到的库文件进行缓冲 。grep命令在ldconfig命令的大量输出结果中查找MySQL库文件,并限定文本以类似下面方式进行显示:
libmysqlclient.so.6 = libmysqlclient.so.6.0.0.
7. echo "/usr/local/mysql/bin/safe_mysqld/dev/null "/etc/rc.d/rc.local
将MySQL启动指令添加到/etc/rc.d/rc.local文件中,这样每次启动Linux后就会自动运行MySQL 。
8. ./scripts/mysql_install_db
初始化数据库 。
9. /usr/local/mysql/bin/safe_mysqld/dev/null
启动MySQL服务器作为后台程序,为了测试安装,MySQL服务器必须启动 。
10. ln -s \
/usr/local/mysql/bin/mysql \
/usr/bin/mysql
我比较喜欢在/usr/bin目录下为安装目录建立符号链接 。这一方法减少了PATH环境变量中的目录数量,还可以将不希望其他人运行的MySQL工具程序隐藏起来,(例如,mysqladmin命令) 。另一方法是将命令PATH="$PATH:/usr/local/mysql/bin"放在/etc/profile文件中 。以上两种方法都很可以采用 。
11. ln -s\
/usr/local/mysql/bin/mysqlshow \
/usr/bin/mysqlshow
该指令是让一般用户都可以运行mysqlshow命令 。
2.4 测试MySQL
在继续Apache和PHP编译之前,首先来测试MySQL的安装是否成功 。正式发布的MySQL带有许多有用的工具 , 这里我们只使用mysql和mysqlshow命令来进行测试 。(如果对数据库不熟悉,请不用担心,诸如用户、表、记录等数据库的概念将在第六章“数据库和SQL”中加以介绍 。)
mysqladmin的作用是建立和删除数据库、检查SQL的状态 , 以及其他一些用途 。首先,通过检查版本号以确认是否已经正确安装了MySQL:
PATH="usr/local/mysql/bin:$PATH"
mysqladmin version
Ver 7.8 Distrib 3.22.16a-gamma, for pc-linux-gun on i686 TCX Datakonsult AB, by Monty
Server version 3.22.16a-gamma
Protocol version 10
Connection Localhost via UNIX socket
UNIX socket /tmp/mysql.sock
Uptime: 2 hours 30 min 39 sec
Threads: 1 Questions: 7 Slow queries: 0
Opens: 6 Flush tables: 1 Open tables: 2
可以用以下命令观看mysqladmin的所有功能.
mysqladmin --help | less
也许mysqlshow是更让人激动的工具,它能够列出数据库、表和字段名,如下所示:
清单2.1 mysqlshow--显示数据库,表和字段名清单
Page 18(第13行)-19(倒数第10行) , 清单 2.1
最后要介绍的MySQL工具是mysql,这个程序将深入到MySQL的中心,并且可以使你可以立刻在Linux命令行提示下执行SQL语句 。在shell模式下运行mysql 。
Page 19(倒数第5行)-20(倒数第5行)
小心:设置密码要使用password()函数 。如果需要进一步了解,请查阅MySQL文档 。
小心:在系统进入正常工作模式的时候 , 请选用一个比“password”更好的root密码 。
2.5 编译iODBC和MyODBC
iODBC是一个实现开放性数据库互连(Open Database connectivity)协议的函数库 。它主要用于连接运行于Microsoft Windows的数据库引擎 。
1. cd /usr/local/src/libiodbc-2.50.3
转到iODBC目录 。
2. ./configure \
--prefix=/usr/local/iodbc \
--with-iodbc-inidir=/usr/local/etc
运行配置程序,并强制设置iODBC为安装到目录/usr/local/iodbc下 。此外 , 应确认odbc的初始化文件为/etc/odbc.ini 。
3. make
4. make install
把库文件复制到目录/usr/local/iodbc/lib下,并且把包含文件复制到目录/usr/local/iodbc/include下 。
5. cd /usr/local/src/myodbc-2.50.24
转到MyODBC目录下 。
6. ./configure \
--prefix=/usr/local/myodbc \
--with-mysql-sources=/usr/local/mysql-3.22.16a-gamma \
--with-odbc-ini=/etc/odbc.ini \
--with-iodbc=/usr/local/iodbc
运行MyODBC配置程序 。
7. make
8. make install
把库复制到目录/usr/local/myodbc/lib下 。
2.6 编译PHP
编译PHP比编译以前的应用程序更复杂,这是因为编译PHP事实上是expat、Apache和PHP的组合 。编译的结果将生成一个带有PHP的Apache版本 。为了要编译PHP , 可以采用以下步骤:
1. cd /usr/local/src/expat
转到expat目录 。
2. make
编译expat源文件 。
3. 把以下命令加到Makefile文件中,必须保证在输入ar和ralib之前使用的是Tab键 。
libexpat.a: $(OBJS)
ar -rc $@ $(OBJS)
ranlib $@
4. make libexpat.a
把expat目标文件组合成库文件 。
5. mv libexpat.a /usr/local/lib
PHP配置文件在/usr/local/lib目录下寻找libexpat.a文件 。把libexpat.a文件移到PHP配置文件已知的目录下,可以为以后的操作减少麻烦 。
6. cd /usr/local/src/php-3.0.11
转到PHP的顶级目录下 。
7. mkdir /usr/local/include/xml
确认/usr/local/include/xml目录是存在的 。
8. ln -s \
/usr/local/src/expat/xmltok/xmltok.h \
/usr/local/include/xml/xmltok.h
当能创建符号连接时,为什么还要复制呢?
9. ln -s \
/usr/local/src/expat/xmlparse.h \
/usr/local/include/xml/xmlparse.h
这是PHP为了能够正确地被编译所需要的另一个包含文件 。
10. cd /usr/local/src/apache_1.3.4
转到Apache的顶级目录下 。
11. ./configure -prefix=/usr/local/apache
运行配置程序,强制设置Apache安装目录为/usr/local/apache 。
12. cd /usr/local/src/php-3.0.11
转到PHP的顶级目录下 。
13. ./configure \
--with-apache=../apache_1.3.4 \
--with-iodbc=/usr/local/iodbc \
--with-mysql=/usr/local/mysql \
--with-xml
运行配置程序,并且告诉配置程序支持Apache、MySQL和XML 。
14. make
编译PHP源文件 。
15. make install
安装已编译的文件 。PHP库文件会被放在Apache的模块目录下,这样可以在编译Apache时能找到它们 。
16. cd /usr/local/src/apache_1.3.4
转到Apache的顶级目录下 。
17. ./configure \
--prefix=/usr/local/apache \
--active-module=src/modules/php3/libphp3.a
再一次配置Apache,这次告诉Apache要加载PHP模块 。
18. make
编译Apache源文件 。
19. make install
安装已编译的文件 。
20. mv \
/usr/local/apache/bin/httpd \
/usr/local/apache/bin/httpd-1.3.4
重新命名新创建的httpd可执行文件,这样就能够安装多种版本 。
21. ln -s \
/usr/local/apache/bin/httpd-1.3.4 \
/usr/sbin/httpd
建立一个指向新的可执行文件的符号链接 。
22. httpd -v
证实可以访问新的可执行文件 。该命令的执行结果将显示版本1.3.4 , 而且建立日期也应该正确无误 。
23. 编辑/usr/local/apache/conf/http.conf文件,搜索AddType并确认下列行未加注释 。
AddType application/x-httpd-php3 .phtml
AddType application/x-httpd-php3 .php3
AddType application/x-httpd-php3-source .phps
24. 接着编辑/usr/local/apache/conf/http.conf文件,搜索DirectoryIndex并将index.php3放在行尾 。
25. 创建一个名为/usr/local/local/php3.ini的文件 , 该文件应包含如下的命令行:
include_path=.:/usr/local/apache/php/
auto_prepend_file=/usr/local/apache/php/prepend.php3
track_vars = on
magic_quotes_gpc = on
sendmail_path /usr/sbin/sendmail -t
26. ln -s \
/usr/local/src/php-3.0.11/doc/manual.html \
/usr/local/src/php-3.0.11/doc/index.html
建立一个符号链接 , 这样绝大多数Web浏览器就会正确地自动显示PHP文件起始页 。
27. ln -s \
/usr/local/src/php-3.0.11/doc \
/usr/local/apache/htdocs/phpdocs
建立一个符号链接,这样就可以通过,来访问PHP文档 。
28. 创建一个叫做/usr/local/apache/htdocs/robots.txt的文件 , 这样就可避免搜索引擎为PHPLIB,phpMyAdmin和PHP文件建立索引,新创建的文件应包括如下设置行:
#robots.txt for (hostname)
User-agent *
Disallow: /phpdocs/
Disallow: /php/
Disallow:/phpMyAdmin/
2.7 安装PHPLIB
在阅读第15章“处理并发的访问”之前,应先安装PHPLIB , 可以按照下列步骤进行安装:
1. 以root用户或其他任何可以在/usr/local/apache目录下写文件的用户注册 。
2. cd /usr/local/apache/
在开始下载文件之前,进入到Web服务器的顶级目录下 。
3. 从如下Web网址下载最新版本的文件 , 注意gz后缀的文件名,以免它的文件名phplib.tar.gz被改动 。
4. tar xv2f phplib.tar.gz
解压缩PHPLIB模块 。
5. 编辑/usr/local/lib/php3.ini文件,应包括下列设置内容:
include_path=.:/usr/local/apache/phplib-6.1/php
auto_prepend_file = /usr/local/apache/phplib-
6.1/php/prepend.php3
track_vars = on
magic_quotes_gpc = on
sendmail_path /usr/sbin/sendmail -t
6. 建立一个名为poe_sessions的mysql数据库 。我一般使用phpMyAdmin,如果愿意 , 也可以使用SQL命令创建数据库 。
7. cd /usr/local/apache/phplib-6.1/stuff
进入建表目录下 。
8. mysql php_book --user=root --password
create_database.mysql
创建PHPLIB所需要的数据库表 。
9. 使用以下值在mysql数据库表中增加一条新记录:
host: %
password: -- no password.
select_priv: Yes
insert_priv: Yes
update_priv: Yes
delete_priv: Yes
for users named "kris","user01",and "user02".
注意:也可以使用如下SQL语句:
INSERT INTO
user
(
Host
,User
,Password
,Select_priv
,Insert_priv
,Update_priv
,Delete_priv
)
VALUES (
'%'
, 'kris'
, ''
, 'Y', 'Y', 'Y', 'Y'
)
10. 使用以下值在mysql数据库的db表中增加一条新记录:
host: %
db: poe_sessions
select_priv: Yes
insert_priv: Yes
update_priv: Yes
delete_priv: Yes
for users named "kris","user01",and "user03".
注意:也可以使用如下SQL程序 。
INSERT INTO
db
(
Host
,Db
,User
,Select_priv
,Insert_priv
,Update_priv
,Delete_priv
)
VALUES (
'%'
, 'poe_sessions '
, 'kris'
, 'Y', 'Y', 'Y', 'Y'
)
11. /usr/local/mysql/bin/mysqladmin -u root -p reload
重新装载MySQL权限表 。
12. 在php_book数据库中创建两个PHPLIB已认证的用户(user01和user02),可以使用如下SQL语句:
INSERT INTO
auto_user
(
uid
,username
,password
,perms
) VALUES (
'c14cbf141ab1b7cd009356f555b1234'
,'user01'
,'test'
,'admin'
)
INSERT INTO
auth_user
(
uid
,username
,password
,perms
) VALUES (
'c14cbf141ab1b7cd009356f555b3241'
,'user02'
,'test'
,'admin'
)
13. mv\ /use/local/apache/phplib-6.1/pages \
/use/local/apach/htdocs
将演示子目录置于Web服务器的根目录下,这样就可以用浏览器访问它 。
14. 编辑文本文件/usr/local/apache/htdocs/robots.txt,使它包括如下内容:
Disallow: /phplib/
15. 使用Web浏览器访问 。将会看到如图2.1所示页面 。
Page 29 图2.1
图2.1 重新装载两次以后出现的PHPLIB演示页面
2.8 测试Linux环境下的ODBC
对所装软件进行基本测试是很重要的 , 特别是需要手工编辑配置文件时 。如下的测试可确保你的MySQL驱动程序运行正常,并且编译的iODBC库文件也是正确无误的 。
1. 使用清单2.1所列的内容 , 建立一个名为/usr/local/etc/odbc.ini的文件 。
清单 2.2/usr/local/etc/odbc.ini- 系统ODBC 配置文件
;
;odbc.ini
;
[ODBC Data Sources]
mysql = mysql
[php_book]
driver = /usr/local/myodbc/lib/libmyodbc.so
host = localhost
database = mysql
user = root
2. cd /usr/local/src/libiodbc-2.50.3/samples
3. ./odbctest
运行ODBC测试程序 。
4. DSN=mysql;PWD=password
告诉测试程序要访问的数据源 。
5. select host,user from user
在提示符下执行一个SQL语句 , 如果有回应,说明iODBC和MySQL已经可以使用了 。
现在,在计算机中已经安装好了ODBC,由于它的安装步骤不太清晰而且文档又很少,所以本章中讲述了其安装和测试指令,然而鉴于ODBC主要是一项Microsoft技术,且很少在Linux中用到,所以这里是本书中最后一次有关介绍 。
2.9 总结:
本章讲述了如何获取PHP,及在计算机中进行安装所需要的步骤,编译了内建PHP的特定版本Apache 服务器 。同时,还安装了将在第15章“中场四:处理并发访问”中用所到的PHPLIB 。
php3数据字典教程的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于php 文本数据库、php3数据字典教程的信息别忘了在本站进行查找喔 。

    推荐阅读