php是可以做数据库的交互的哦,php还是一门比较全面的语言,如果有意向去学php建议你去找个好点的学校去php,学会了肯定是非常强大的
PHP
PHP,一个嵌套的缩写名称,是英文超级文本预处理语言(PHP:Hypertext Preprocessor)的缩写.PHP 是一种 HTML 内嵌式的语言,PHP与微软的ASP颇有几分相似,都是一种在服务器端执行的嵌入HTML文档的脚本语言,语言的风格有类似于C语言,现在被很多的网站编程人员广泛的运用.PHP 独特的语法混合了 C、Java、Perl 以及 PHP 自创新的语法.它可以比 CGI 或者 Perl 更快速的执行动态网页.用PHP做出的动态页面与其他的编程语言相比,PHP是将程序嵌入到HTML文档中去执行,执行效率比完全生成HTML标记的CGI要高许多;与同样是嵌入HTML文档的脚本语言JavaScript相比,PHP在服务器端执行,充分利用了服务器的性能;PHP执行引擎还会将用户经常访问的PHP程序驻留在内存中,其他用户再一次访问这个程序时就不需要重新编译程序了,只要直接执行内存中的代码就可以了,这也是PHP高效率的体现之一.PHP具有非常强大的功能,所有的CGI或者JavaScript的功能PHP都能实现,而且支持几乎所有流行的数据库以及操作系统.
PHP的特性
PHP的特性包括:
开放的源代码:所有的PHP源代码事实上都可以得到.
PHP是免费的.
php的便捷性 : php十分便捷
基于服务器端:由于PHP是运行在服务器端的脚本,可以运行在UNIX、LINUX、WINDOWS下.
嵌入HTML:因为PHP可以嵌入HTML语言,所以学习起来并不困难.
简单的语言:PHP坚持脚本语言为主,与Java和C++不同.
效率高:PHP消耗相当少的系统资源.
图像处理:用PHP动态创建图像
数据库方面
PHP 在数据库方面的丰富支持,也是它迅速走红的原因之一,它支持下列的数据库或是数据文件:
- Adabas D
- DBA
- dBase
- dbm
- filePro
- Informix
- InterBase
- mSQL
- Microsoft SQL Server
- MySQL
- Solid
- Sybase
- ODBC
- Oracle
- PostgreSQL
除此之外,用 PHP 写出来的 Web 后端 CGI 程序,可以很轻易的移植到不同的操作系统上.例如,先以 Linux 架的网站,在系统负荷过高时,可以快速地将整个系统移到 SUN 工作站上,不用重新编译 CGI 程序.面对快速发展的 Internet,这是长期规划的最好选择.
变数类型:
PHP有好多种变数; 主要有这些:
- 布林值 (boolean - 例: TRUE)
- 字串 (string - 例: 'a string of text')
- NULL
- 资源(resource)
语法:
语法有三种:
//comment
/* comment */
# comment
基本的 "Control Structures":
* if ... else
if (condition == true) ;
* if ... else then
if (condition == true)
一个PHP实例:
html
head
titleFirst program/title
/head
body
php
echo "hello world";
/body
/html
请看:
php官方网站:
php对面向对象的支持
面向对象编程的概念:
抽象数据类型和信息封装
继承
多态
在PHP中是通过类来完成封装的:
class Something {
// 在OOP类中,通常第一个字符为大写
var $x;
function setX($v) {
// 方法开始为小写单词,然后使用大写字母来分隔单词,例如getValueOfArea()
$this-x=$v;
}
function getX() {
return $this-x;
当然你可以按自己的喜好进行定义,但最好保持一种标准,这样会更有效.数据成员在类中使用"var"声明来定义,在给数据成员赋值之前,它们是没有类型的.一个数据成员可以是一个整数,一个数组,一个相关数组(associative array)或者是一个对象.方法在类中被定义成函数形式,在方法中访问类成员变量时,你应该使用$this-name,否则对一个方法来说,它只能是局部变量.
使用new操作符来创建一个对象:
$obj=new Something;
然后你可以使用成员函数通过:
$see=$obj-getX();
class Another extends Something {
var $y;
function setY($v) {
$this-y=$v;
function getY() {
return $this-y;
"Another"类的对象现在拥有了父类(Something)的全部的数据成员及方法,而且还加上了自己的数据成员和方法.
你可以使用
PHP现在还不支持多重继承,所以你不能从两个或两个以上类派生出新的类来.你可以在派生类中重定义一个方法,如果我们在"Another"类中重定义了getX方法,我们就不能使 用"Something"中的getX方法了.如果你在派生类中声明了一个与基派同名的数据成员,那么当你处理它时, 它将"隐藏"基类的数据成员.
你可以在你的类中定义构造函数.构造函数是一个与类名同名的方法,当你创建一个类的对象时会被调用,例如:
function Something($y) {
$this-x=$y;
所以你可以创建一个对象,通过:
接着:
缺省参数使用C++的方式,所以你不能忽略Y的值,而给X一个缺省参数,参数是从左到右赋值的,如果传入的参数少于要求的参数时,其作的将使用缺省参数.
当一个派生类的对象被创建时,只有它的构造函数被调用,父类的构造函数没被调用,如果你想调用基类的构造函数,你必须要在派生类的构造函数中显示调用.可以这样做是因为在派生类中所有父类的方法都是可用的.
function Another() {
$this-Something();
//显示调用基类构造函数
OOP的一个很好的机制是使用抽象类.抽象类是不能实例化,只能提供给派生类一个接口.设计者通常使用抽象类来强迫程序员从基类派生,这样可以确保新的类包含一些期待的功能.在PHP中没有标准的方法,但是:如果你需要这个特性,可以通过定义基类,并在它的构造函数后加上"die" 的调用,这样就可以保证基类是不可实例化的,现在在每一个方法(接口)后面加上"die" 语句,所以,如果一个程序员在派生类中没有覆盖方法,将引发一个错误.而且因为PHP 是无类型的,你可能需要确认一个对象是来自于你的基类的派生类,那么在基类中增加一个方法来实义类的身份(返回某种标识id),并且在你接收到一个对象参数时校验这个值.当然,如果一个邪恶不好的程序员在派生类中覆盖了这个方法,这种方法就不起作用了,不过一般问题多发现在懒惰的程序员身上,而不是邪恶的程序员.
当然,能够让基类对程序员无法看到是很好的,只要将接口打印出来做他们的工作就可以了.在PHP中没有析构函数.
重载(与覆盖不同)在PHP中不支持.在OOP中,你可以重载一个方法来实现两个或重多的方法具有相同的名字,但是有不同数量或类型的参数(这要看语言).PHP 是一种松散类型的语言,所以通过类型重载不起作用,然而通过参数的个数不同来重载也不起作用.
有时在OOP中重载构造函数非常好,这样你可以通过不同的方法创建对象(传递不同数量的参数).在PHP中实现它的技巧是:
class Myclass {
function Myclass() {
$name="Myclass".func_num_args();
$this-$name();
//注意$this-name()一般是错误的,但是今天这一节$name是一个将被调用方法的名字
function Myclass1($x) {
code;
通过在类中的额外的处理,使用这个类对用户是透明的:
$obj1=new Myclass('1'); //将调用Myclass1
有时这个非常好用.
多态是对象的一种能力,它可以在运行时刻根据传递的对象参数,决定调用哪一个对象的方法.例如,如果你有一个figure的类,它定义了一个draw的方法.并且派生了circle和rectangle 类,在派生类中你覆盖了draw方法,你可能还有一个函数,它希望使用一个参数x,并且可以调用$x-draw() .如果你有多态性,调用哪个draw方法就依赖于你传递给这个函数的对象类型.
多态性在象PHP这样的解释语言(想象一下一个C++编译器生成这样的代码,你应该调用哪一个方法?你也不知道你拥有的对象是什么类型的,好,这不是重点)是非常容易和自然的.所以PHP当然支持多态性.
function niceDrawing($x) {
//假设这是Board类的一个方法
$x-draw();
$board-niceDrawing($obj);
//将调用Circle的draw方法
//将调用Rectangle的draw方法
用PHP进行面向对象编程
一些"纯化论者(purists)"可能会说PHP不是一个真正的面向对象的语言,这是事实.PHP 是一个混合型语言,你可以使用OOP,也可以使用传统的过程化编程.然而,对于大型项目,你可能想/需要在PHP 中使用纯的OOP去声明类,而且在你的项目只用对象和类.
随着项目越来越大,使用OOP可能会有帮助,OOP代码很容易维护,容易理解和重用.这些就是软件工程的基础.在基于web的项目中应用这些概念就成为将来网站成功的关键.
以上内容来自 百度百科
PHP(中文名:"超文本预处理器")是一种通用开源脚本语言.语法吸收了C语言、Java和Perl的特点,利于学习,使用广泛,主要适用于Web开发领域.
PHP独特的语法混合了C、Java、Perl以及PHP自创的语法.它可以比CGI或者Perl更快速地执行动态网页.用PHP做出的动态页面与其他的编程语言相比,PHP是将程序嵌入到HTML文档中去执行,执行效率比完全生成HTML标记的CGI要高许多.
PHP还可以执行编译后代码,编译可以达到加密和优化代码运行,使代码运行更快.
PHP在数据库方面的丰富支持,也是它迅速走红的原因之一,它支持下列的数据库或是数据文件:
Adabas 、D、 DBA、dBase 、dbm 、filePro 、Informix 、InterBase、mSQL 、Microsoft SQL Server、-MySQL、Solid、Sybase、 Oracle 、PostgreSQL
扩展资料:
①.、PHP独特的语法混合了 C、Java、Perl 以及 PHP 自创新的语法.
参考资料:
百度百科--PHP
最低水平,PHP可以做任何其他CGI程序所能做的事,例如收集表格数据,生成动态页面内容,或者收发cookies.可能最强大,最有意义的特性是PHP支持大范围的数据库.书写一个支持数据库的Web 页面是难以置信的简单.
下面是当前支持的数据库:
Adabas D InterBase Solid
dBase mSQL Sybase
Empress MySQL Velocis
FilePro Oracle Unix dbm
Informix PostgreSQL
PHP的简要历史
PHP 是一种用来制作动态网页的服务器端脚本语言.你通过PHP和HTML创建页面.当访问者打开网页时,服务器端便会处理 PHP 指令,然后把其处理结果送到访问者的浏览器上面,就好像 ASP 或者是 ColdFusion 一样.然而,PHP 跟 ASP 或 ColdFusion 不一样的地方在于,它是跨平台的开放源代码.PHP 可以在 Windows NT 以及很多不同的 Unix 版本中执行,它也可以被编译为一个 Apache 模块,或者是一个CGI二进制文件.当被编译为 Apache 模快时,PHP 尤其轻巧方便.它没有任何繁琐程序所产生的负担,所以呢可以很快的返回结果,同时也不需为了保持较小的服务器内存映象,而去调整mod_perl.
① 引言
SQL是什麼?
* SQL (Structured Query Language)代表结构化查询语言.
* 当用户发出一项查询,便可从数据库档内获得若干资料.这项查询是根据用户所提供的条件 (condition) 所作出的一项检索.而 SQL则是一个可让用户把条件列明的查询语言.这样,用户只须列明查询的条件,而不须要实际知道有关的检索方法.
* 一般的数据库管理软件系统 (DBMS) 都包含 SQL 功能.
SQL的概念
* 用户除了直接查问各笔记录的资料外,也可查问统计数项,例如最大值、最小值、总和及平均值.
* 查询所得的结果会以表格的形式显示,用户亦可指示 SQL 程序把结果贮存成为数据库档.
在 FoxPro 如何使用 SQL
* 使用 SQL,必须先把有关数据库档开启.
* 用户可使用指令视窗 (Command Window) 直接把指令输入,亦可使用对话方块把指令输入.
* 若用户选用字符串的完全配对时,便须输入 SET ANSI ON.
一般语法 SELECT, ALL / DISTINCT, *,
AS, FROM, WHERE
比较 IN, BETWEEN, LIKE "% _"
群组 GROUP BY, HAVING,
COUNT( ), SUM( ), AVG( ), MAX( ), MIN( )
显示次序 ORDER BY, ASC / DESC
逻辑运算符 AND, OR, NOT
输出 INTO TABLE / CURSOR
TO FILE [ADDITIVE], TO PRINTER, TO SCREEN
联合 UNION
简称:
expr = 表达式 expression, groupexpr = 群组表达式 group expression
col = 栏 column, comcol = 共同栏 common column
colname = 栏名 column name
nullval = 空值 null value
实例:学生个人资料
例子: 考虑以下贮存学生数据的数据库档 STUDENT. DBF:
(i) hcode 表示学生的社名(即红黄蓝绿四社).
R = Red, Y = Yellow, B = Blue, G = Green
(ii) dcode 表示学生的居住地区码.
eg. TST = 尖沙咀(Tsim Sha Tsui), MKK = 旺角(Mong Kok)
(iii) remission 表示学生是否享有学费减免:
.T. =享有学费减免, .F. = 没有学费减免
(iv) mtest 贮存学生数学测验的分数,满分为100.
栏名 类型 栏宽 内容
name 字符 10 学生名字
sex 字符 1 性别: M / F
hcode 字符 1 社名: R, Y, B, G
remission 逻辑 1 学费减免
I 一般语法
SELECT ...... FROM ...... WHERE ......
FROM tablename WHERE condition
– SQL 程序会从数据库档 tablename 选取符合条件的横列 (row) 并以表格的格式显示.
– 选项 DISTINCT 会把重覆出现的横列删去(即只显示一次),而选项 ALL 则会把所有重覆的保留.
在使用SQL之前,开启数据库档:
USE student
例 1 求出所有学生的资料.
SELECT * FROM student
注意: 1) 这个指令并不提出任何条件,所以把 WHERE 部分省去.
id
name dob sex class mtest hcode dcode remission
: : : : : : : : :
SELECT name, hcode, class FROM student ;
WHERE class="1A"
name
hcode class
Peter R 1A
Mary Y 1A
Johnny G 1A
Luke G 1A
Bobby B 1A
Aaron R 1A
: : :
SELECT DISTINCT dcode FROM student ;
WHERE hcode="R"
注意: 若两个或以上的学生居住於同一地区,使用选项 DISTINCT 便可把重覆的结果省去.
dcode
HHM
KWC
MKK
SSP
TST
YMT
WHERE class="1B" AND sex="F"
注意: 1) 「1B 班女生」的条件包括两部分:class="1B" 和 sex="F".而这项条件必须同时符合,所以要使用逻辑运算符 AND.
age
SELECT name, id, class FROM student ;
WHERE class="1A" AND NOT remission
注意: 1) 这裏包括两项条件:学生必须是 1A 班,而且没有享有学费减免. 所以在 WHERE 部分中加上运算符 AND.
id class
II 比较
expr LIKE "%_"
– 在 WHERE 部分中,可使用以上的比较条款:
SELECT name, class, CDOW(dob) AS bdate FROM student ;
class bdate
Peter 1A Wednesday
Wendy 1B Wednesday
Kevin 1C Saturday
Luke 1A Wednesday
Aaron 1A Saturday
SELECT name, class, dob FROM student ;
class dob
SELECT name, mtest FROM student ;
mtest
SELECT name, class FROM student ;
WHERE name LIKE "T%"
注意: 这裏所用的样式是 "T%" ,这表示第一个字符必须是 "T" 而其后可以是任何的字符串.
class
Tobe 1B
Teddy 1B
例10 求出所有红社社员其名字的第二个字母是"a".
SELECT name, class, hcode FROM student ;
WHERE name LIKE "_a%" AND hcode="R"
注意: 这裏所用的样式是 "_a%" ,而其中的 "_" 符号代表任何单一字符,亦即第一个字符是任意的.第二个字符则必须是 "a",而其后的 "%" 代表任何的字符串.
class hcode
Aaron 1A R
Janet 1B R
III 群组
SELECT ...... FROM ...... WHERE condition ;
GROUP BY groupexpr [HAVING requirement]
群组函数: COUNT( ), SUM( ), AVG( ), MAX( ), MIN( )
–GROUP BY groupexpr 列出群组组成所依照的表达式.一般都是数据库档的一栏.
– WHERE condition 列出个别横列所须符合的条件,而 HAVING requirement 则列出个别群组须符合的条件.
– 可使用以群组函数来计算统计数项:
COUNT( ): 记录出现的目数
SUM( ): 总和
AVG( ): 平均值
MAX( ): 最大值
MIN( ): 最小值
例11 求出每一班的人数.
SELECT class, COUNT(*) FROM student
GROUP BY class
注意: 1) 使用 GROUP BY class, SQL 程序便会先把表格裏的横列按照 class 排列起来.
cnt
①.A 10
SELECT class, AVG(mtest) FROM student GROUP BY class
注意: SQL 程序会先依照 class 来群组,然后在每一组中计算该组的 mtest 平均值.
avg_mtest
SELECT dcode, COUNT(*) FROM student ;
WHERE sex="F" GROUP BY dcode
注意: 查询的条件为 sex="F".而 SQL 程序会先把符合这条件的横列选出,然后把这些横列依照 dcode 为群组.
KWC 1
MKK 1
SELECT MAX(mtest), MIN(mtest), dcode FROM student ;
WHERE class LIKE "1_" GROUP BY dcode
max_mtest
min_mtest dcode
注意: 这例使用条件 class LIKE "1_" 来拣选每区的中一学生.
SELECT AVG(mtest), class FROM student ;
IV 显示次序
SELECT ...... FROM ...... WHERE ...... GROUP BY ..... ;
ORDER BY colname ASC / DESC
– ORDER BY colname 控制结果的显示序.而 colname 代表结果表格的一栏.而ASC = 升幂, DESC = 降幂.
SELECT name, id FROM student ;
WHERE sex="M" AND class="1A" ORDER BY name
name id name id
Peter
SELECT name, id, class, dcode FROM student ;
name id class dcode
SELECT COUNT(*) AS cnt, dcode FROM student ;
GROUP BY dcode ORDER BY cnt DESC
docode
①.1 YMT
①.0 HHM
①.0 SSP
①. KWC
①. MMK
①. SHT
WHERE sex="M" ORDER BY hcode, class
注意: 这些横列先按 hcode 排列(即第一层排列);而相同的 hcode,再按 class 次序显示.
name hcode class
Bobby
B 1A
Teddy B 1B
Kevin G 1C
George G 1C
: : :
V 输出
INTO TABLE tablename
把查询所得的结果贮存成数据库档.
INTO CURSOR temp
把查询所得的结果暂时贮存於电脑的工作记忆裏.
TO FILE filename [ADDITIVE]
把查询所得的结果贮存成文字档.(additive = 附加)
TO PRINTER 输出到列印机.
TO SCREEN 输出到萤幕.
SELECT * FROM student ;
ORDER BY name DESC INTO TABLE name.dbf
注意: 1) INTO TABLE name.dbf 要求 SQL 程序把结果贮存成档案.
:
: : : : : : : :
SELECT class, name, sex FROM student ;
WHERE hcode="R" ;
ORDER BY class, sex DESC, name TO PRINTER
注意: 1) 这指令要求程序先找出绿社社员,然后把这些横列以 class, sex 和 name 的次序排列.
name sex
Aaron M
Peter M
①.A Ron M
①.B Tobe M
①.B Janet F
①.B Kitty F
Mimi F
考虑两个结构相同的数据库档 A 和 B.
A 和 B 的联合
(A B) union
检取属於 A 或 B 的所有横列.
A 和 B 的相交
(A B) intersection
检取 A 和 B 所共有的横列.
A 和 B 的差分
(A–B) difference 检取只属於 A 而不属於 B 的横列.(即从 A 把 B 的部分排出)
SELECT ...... FROM ...... WHERE ...... ;
UNION ;
SELECT ...... FROM table1 ;
实例:桥牌会和棋艺会
考虑学校桥牌会和棋艺会的会员,他们的资料分别贮存於同一结构的数据库档 BRIDGE.DBF 和 CHESS.DBF 内:
Bridge [A] Chess [B]
id name sex class id name sex class
: : : : : : : :
在使用SQL之前,开启这两个数据库档:
SELECT A
USE bridge
SELECT B
USE chess
SELECT * FROM bridge ;
SELECT * FROM chess ;
ORDER BY class, name INTO TABLE party
注意: 所要求的是两会的所有会员,这便是两会的联合.
Party
id name sex class
: : : :
WHERE id IN ( SELECT id FROM chess ) ;
TO PRINTER
注意: 这例须找出两会所共通的会员.SQL 程序须检查桥牌会的每一个会员是否也属於棋艺会.若是属於的话,这人便符合这个要求了.
Common
WHERE id NOT IN ( SELECT id FROM chess ) ;
INTO TABLE diff
注意: 1) 这例须从桥牌会中拣选那些并不属於棋艺会的人.所以 SQL 程序须使用 FROM bridge,即从逐一检查桥牌会的会员是否属於棋艺会,若不属於的话,这人便符合这个要求了.
Diff
Id name sex class
当所查询的资料贮放於两个数据库档时,就须使用接合 (join). 接合的作用是把一个数据库档内的一个横列与另一个数据库档内的横列连合起来,从而把所有不同的组合列出来. (数学: Cartesian Product)
自然接合
* 在接合中加上一项接合条件,要求两档的共通栏(common column)的值是相同,这称为自然接合.这目的是要把这两档的相关资料连合起来,变成一个合一的大表格,再从这表格中执行查询工作.
WHERE a.comcol = b.comcol
– 在自然接合中,这两个数据库档须要有一个栏是相同的,这一栏称为共通栏 .SQL 程序会先把这两档的所有组合列出,然后从中拣选共通栏的值是相同的横列.
实例:乐器班
学校规定每个学生都须要学习一件乐器.现在使用数据库档 MUSIC.DBF 贮存学生所学的乐器名称 (而学生的其他资料则贮存於 STUDENT.DBF 内)
type 字符 10 乐器名称
SELECT s.class, s.name, s.id, m.type FROM student s, music m ;
WHERE s.id=m.id ORDER BY class, name
注意: 1) 这裏用了s 代表 student.dbf 而 m 代表 music.dbf.
name id type
SELECT s.class, COUNT(*) FROM student s, music m ;
WHERE s.id=m.id AND m.type="Piano" ;
GROUP BY class ORDER BY class
注意: 1) 裏先首先用了接合条件 s.id=m.id 把两档自然接合起来.
class cnt
①.C 1
外接合
* 外接合是自然接合再加上没有配合的部分.
WHERE a.comcol = b.comcol ;
SELECT comcol, col1, nullval, nullval, nullval ;
FROM table1 ;
– 外接合的指令包括两个 SELECT 部分,再以 UNION 联会起来.
– 第一部分是自然接合(即成功接合),第二部分则是没有配合(即是在第一部分不能自然接合的横列).
– 为了使第二部分与第一部分的结构一样,第二部分中没有数值的位置须填上空值 (null value),即空字符串""、数值零、 逻辑值 .F. 或空日期 { / / } .
SELECT class, name, id FROM student ;
WHERE id NOT IN ( SELECT id FROM music ) ;
ORDER BY class, name
注意: 1) 这指令会从 student.dbf 中选出那些在另一档 music.dbf 没有配合的横列.
name id
SELECT s.class, s.name, s.id, m.type ;
FROM stu
PHP属于编程语言的一种,是一种用于创建动态和交互式HTML网页的脚本语言.
编程语言是一种被标准化的交流技巧,用来向计算机发出指令,定义计算机程序,让程序员能够准确地定义计算机所需要使用的数据,并精确地定义在不同情况下所应当采取的行动的一种计算机语言.而编程语言包含很多细分,而PHP就是其中一种.
它的主要特性为:
①开源性和免费性
由于PHP的解释器的源代码是公开的,所以安全系数较高的网站可以自己更改PHP的解释程序.另外,PHP运行环境的使用也是免费的.
②快捷性
③数据库连接的广泛性
PHP可以与很多主流的数据库建立起连接,如MySQL、ODBC、Oracle等,PHP是利用编译的不同函数与这些数据库建立起连接的,PHPLIB就是常用的为一般事务提供的基库.
④面向过程和面向对象并用
在PHP语言的使用中,可以分别使用面向过程和面向对象,而且可以将PHP面向过程和面向对象两者一起混用,这是其它很多编程语言是做不到的.
优点
①流行,容易上手
②开发职位很多
在服务器端的网站编程中PHP会更容易帮助你找到工作.很多互联网相关企业都在使用PHP开发框架,所以可以说市场对PHP的开发程序员的需求还是比较大的.
③仍然在不断发展
④可植入性强
PHP语言在补丁漏洞升级过程中,核心部分植入简单易行,且速度快.
⑤拓展性强
PHP语言在数据库应用过程中,可以从数据库调取各类数据,执行效率高
PHP是逻辑语言,数据库是存放信息的.PHP通过逻辑去数据库调用客户想看的数据.