php数据访问对象 php访问数据库的方式

PHP访问MYSQL数据库封装类(附函数说明)复制代码
代码如下:
?php
/*
MYSQL
数据库访问封装类
MYSQL
数据访问方式,php4支持以mysql_开头的过程访问方式,php5开始支持以mysqli_开头的过程和mysqli面向对象
访问方式,本封装类以mysql_封装
数据访问的一般流程:
1,连接数据库
mysql_connect
or
mysql_pconnect
2,选择数据库
mysql_select_db
3,执行SQL查询
mysql_query
4,处理返回的数据
mysql_fetch_array
mysql_num_rows
mysql_fetch_assoc
mysql_fetch_row
etc
*/
class
db_mysql
{
var
$querynum
=
;
//当前页面进程查询数据库的次数
var
$dblink
;
//数据库连接资源
//链接数据库
function
connect($dbhost,$dbuser,$dbpw,$dbname='',$dbcharset='utf-8',$pconnect=0
,
$halt=true)
{
$func
=
empty($pconnect)
?
'mysql_connect'
:
'mysql_pconnect'
;
$this-dblink
=
@$func($dbhost,$dbuser,$dbpw)
;
if
($halt
!$this-dblink)
{
$this-halt("无法链接数据库!");
}
//设置查询字符集
mysql_query("SET
character_set_connection={$dbcharset},character_set_results={$dbcharset},character_set_client=binary",$this-dblink)
;
//选择数据库
$dbname
@mysql_select_db($dbname,$this-dblink)
;
}
//选择数据库
function
select_db($dbname)
{
return
mysql_select_db($dbname,$this-dblink);
}
//执行SQL查询
function
query($sql)
{
$this-querynum
;
return
mysql_query($sql,$this-dblink)
;
}
//返回最近一次与连接句柄关联的INSERT,UPDATE
或DELETE
查询所影响的记录行数
function
affected_rows()
{
return
mysql_affected_rows($this-dblink)
;
}
//取得结果集中行的数目,只对select查询的结果集有效
function
num_rows($result)
{
return
mysql_num_rows($result)
;
}
//获得单格的查询结果
function
result($result,$row=0)
{
return
mysql_result($result,$row)
;
}
//取得上一步
INSERT
操作产生的
ID,只对表有AUTO_INCREMENT
ID的操作有效
function
insert_id()
{
return
($id
=
mysql_insert_id($this-dblink))
=
?
$id
:
$this-result($this-query("SELECT
last_insert_id()"),
0);
}
//从结果集提取当前行 , 以数字为key表示的关联数组形式返回
function
fetch_row($result)
{
return
mysql_fetch_row($result)
;
【php数据访问对象 php访问数据库的方式】}
//从结果集提取当前行 , 以字段名为key表示的关联数组形式返回
function
fetch_assoc($result)
{
return
mysql_fetch_assoc($result);
}
//从结果集提取当前行,以字段名和数字为key表示的关联数组形式返回
function
fetch_array($result)
{
return
mysql_fetch_array($result);
}
//关闭链接
function
close()
{
return
mysql_close($this-dblink)
;
}
//输出简单的错误html提示信息并终止程序
function
halt($msg)
{
$message
=
"html\nhead\n"
;
$message
.=
"meta
content='text/html;charset=gb2312'\n"
;
$message
.=
"/head\n"
;
$message
.=
"body\n"
;
$message
.=
"数据库出错:".htmlspecialchars($msg)."\n"
;
$message
.=
"/body\n"
;
$message
.=
"/html"
;
echo
$message
;
exit
;
}
}
?
PHP访问MySQL数据库的步骤 。PHP访问MySQL数据库:
因为连接数据库需要较长的时间和较大的资源开销,所以如果在多个网页中都要频繁地访问数据库 , 则可以建立与数据库的持续连接 。即调用mysql_pconnect()代替mysql_connect() 。
基本步骤:
1.连接服务器:mysql_connect();
2.选择数据库:mysql_select_db();
3.执行SQL语句:mysql_query();
查询:select
显示:show
插入:insert into
更新:update
删除:delete
4.关闭结果集:mysql_free_result($result);
5.关闭数据库:mysql_close($link);
为什么 PHP 应该使用 PDO 方式访问数据库pdo是面向对象php数据访问对象的,pdo可以连接多种数据库使用
我在php里边建了一个数组,然后想访问数组中元素,服务器端能得到数据,为什么页面上显示未定义jsp一共有9个内置对象,分别是以下9个:
1.Request对象
发送请求时,该对象被创建,一次请求结束后即销毁 。(一次请求产生一个request对象)
该对象封装了用户提交的信息,通过调用该对象相应的方法要以获取封装的信息 。即,使用该对象可以获取用户提交的信息 。
当Request对象获取客户提交的内容为汉字字符时,会出现乱码现象,则必须进行特殊处理 。首先,将获取的字符串用ISO8859-1进行编码,并将编码存放到一个字节数组中,然后将这个数组转化为字符串对象即可 。如下代码:
Stringtext = request.getParameter("body");
byte [] b = text.getBytes("ISO8859-1");//将text字符串转换成字节数组---编码的过程
text = new String(b);//构造字符串,按照当前操作系统的字符集进行构造 。将字节转换成字符串---解码的过程
Request常用的方法:
getParameter(String s)----- 获取表单提交的信息
Strings = request.getParameter("name");
getProtocol()-----获取客户使用的协议
Strings = request.getProtocol() ;
getServletPath()----获取客户提交信息的页面
Strings = request.getServletPath();
getMethod()-----获取客户提交信息的方式get或post
Strings = request.getMethod();
getHeader()----- 获取HTTP头文件中的accept、accept-encoding和host的值
Strings = request.getHeader("accept");
getRemoteAddr()--获取客户的ip地址
Strings = request.getRemoteAddr();
getServerHost()---获取客户机的名称
Strings = request.getServerHost();
getServerName()---获取服务器名称
Strings = request.getServerName();
getServerPort()----获取服务器的商口号
Strings = request.getServerPort();
getPamameterNames() ----获取客户端提交的所有参数的名字
Enumerationenum = request.getParameterNames();
while(enum.hasMoreElements()){
Strings = (String) enum.nextElement();
out.println(s);
}
2. Response对象:对客户的请求做出动态响应,向客户端发送数据 。响应客户请求时创建,响应结束时销毁 。(一次响应产生一个response对象)
动态响应contentType属性
当一个用户访问了一个jsp页面时,如果该页面用page指令设置页面的contentType属性为text/html , 那么jsp引擎将按照这个属性值做出反应 。如果要动态改变这个属性值来响应客户 , 就需要使用Response对象的setContentType(Strings);方法来改变contentType属性的值 。
格式:response.setContentType(Strings) -----参数s可?。簍ext/html,application/x-msexcel,application/msword等
Response重定向
在某些情况下,当响应客户时 , 需要将客户重新引导到另一个页面,可以使用Response的sendRedirect(URL);方法,实现客户的重定向
格式:response.sendRedirect("index.jsp");
3. Session对象:在页面的page指令加上session="true" 或缺省 情况下以及在servlet中使用request.getSession();的方式进行创建 。超时或服务停止时,session结束 。(一个用户对应一个session对象)
什么是session对象? ----- 它是一个jsp内置对象,它在第一个jsp被装载时自动创建,完成会话期管理 。从一个客户打开浏览器并连接到服务器开始,到客户关闭浏览器离开这个服务器结束(或者超时),被称为一个会话 。当一个客户访问一个服务器时,可能会在这个服务器的几个页面之间切换,服务器应当通过某种办法知道这是一个客户,就需要创建session对象 。
session对象的ID -----当一个客户首次访问服务器上的一个jsp页面时,jsp引擎会产生一个session对象 , 同时分配一个String类型的的ID号,jsp引擎同时将这个ID号发送到客户端,存放在cookie中,这样,session对象直到客户关闭浏览器后,服务器端,该客户的session对象才会消失,会并,和客户的会话对应关系消失 。当客户重新打开浏览器再连接到该服务器时,服务器为该客户再创建一个新的session对象 。
session对象的常用方法:
publicStringgetId()----获取Session对象的编号
pulbicvoidsetAttribute(Stringkey,Objectobj) --- 将参数object指定的对象obj添加到Session对象中,并为添加的对象指定一个索引关键字
publicObjectgetAttribute(Stringkey) --- 获取session对象中含有关键字的对象
publicBlooeanisNew() ----判断是否为一个新的客户
4.Application对象:启动服务时创建,停止服务时销毁 。(整个程序只有一个application对象)
什么是Application对象? --- 服务器启动后就产生了这个Application对象,当客户在所访问的的网站的各个页面之间浏览时,这个Application对象都是同一个 , 直到服务器关闭 。但是,与session对象不同的是,所有客户的Application对象都是同一个,即,所有客户共享这个内置的Application对象 。
Application对象的常用方法
setAttribute(Stringkey , Ojbectobj)----将参数obj添加到Application对象中,并为添加的对象指定一个索引关键字
getAttribute(Stringkey); ---- 获取Application对象中含有关键字的对象
5.Out对象:请求时,就创建,请求结束时,销毁 。(一个请求,创建一个out对象)
Out对象是一个输出流,用来向客户端输出数据 。out对象用于各种数据的输出 。其常用方法如下:
out.print(); ---- 向浏览器输出各种类型数据
out.newLine(); --- 输出一个换行符
out.close(); ---关闭流
6.cookie对象:
什么是cookie?----cookie是web服务器保存在用户硬盘上的一段文本 。cookie允许一个web站点在用户电脑上保存信息并且随后再取它 。
举例来说,一个web站点可能会为每一个访问者产生一个唯一的ID、然后以cookie文件的形式保存在每个用户的机器上 。
如果用户选择的是IE浏览器访问web,用户就会看到所有保存在自己硬盘上的cookie 。它们最常存放的地方是:c:/Windows/Cookies 。cookie是以”关键字 key = 值value“的格式来保存记录的 。
创建一个cookie对象
调用cookid对象的构造函数就可以创建cookie对象 。cookie的构造函数有两个字符串参数:cookie名字和cookie值 。
如:Cookiec = new Cookie("username","hyc");
将cookie对象传送到客户端
在jsp中,如果要将封装好的cookie对象传送到客户端 , 可使用Response对象的addCookie()方法
如:Response.addCookie();
读取保存在客户端的cookie
使用request对象的getCookie()方法,执行时,将所有客户端传来的cookie对象以数组的形式排列 。如果要取出更符合需求的cookie对象 , 就需要循环比较数组内每个对象的关键字 。
如:Cookie [] c = request.getCookies();
if (c! = null){
for (int i = 0;ic.length;i){
if("username".equals("c,getName))
out.println(c.getValue());
}
}
设置cookie对象的有效时间
调用cookie对象的setMaxAge()方法,可以设置cookie对象的有效时间 。如
Cookiec = new Cookie("username","hyc");
c.setMaxAge(3600);
cookie应用
cookie对象的典型应用是用来统计网站的访问人数 。由于代理服务器、缓存等的使用,唯一能帮助网站精确统计来访人数的方法就是为每个访问者建立一个唯 一的ID 。使用cookie , 网站可以完成以下工作
测试定多少人访问过;
测定访问者有多少是新用户(即第一次来访)、有多少老用户;
测定一个用户多久访问一次网站
当一个用户第一次访问时,网站在数据库中建立一个新的ID , 并把ID通过Cookie传送给用户 。用户再次来访时,网站把该用户的ID对应的计数器加1,得到用户来访的次数 。
7.config对象:配置对象
8.page对象:页面对象
9.Exception对象:在处理异常的网页中可以直接访问exception隐式对象
PHP数组转对象之后,怎么用对象的方式访问数据这里定义2个php匿名对象和数组相互转换的函数 , 代码如下:
function array2object($array) {
if (is_array($array)) {$obj = new StdClass();foreach ($array as $key = $val){$obj-$key = $val;}}else { $obj = $array; }return $obj;}function object2array($object) {if (is_object($object)) {foreach ($object as $key = $value) {$array[$key] = $value;}}else {$array = $object;}return $array;}
用法示例如下:
$array = array('foo' = 'bar','one' = 'two','three' = 'four');$obj = array2object($array);print $obj-one; // output's "two"$arr = object2array($obj);print $arr['foo']; // output's bar
pdo是什么意思?PDO(PHP Data Objects)是一种在PHP里连接数据库的使用接口 。PDO与mysqli曾经被建议用来取代原本PHP在用的mysql相关函数,基于数据库使用的安全性,因为后者欠缺对于SQL注入的防护 。
PHP 数据对象(PDO) 扩展为PHP访问数据库定义了一个轻量级的一致接口 。实现 PDO 接口的每个数据库驱动可以公开具体数据库的特性作为标准扩展功能 。注意利用 PDO 扩展自身并不能实现任何数据库功能;必须使用一个具体数据库的 PDO 驱动来访问数据库服务 。
相关信息:
PDO 提供了一个数据访问抽象层 , 这意味着,不管使用哪种数据库,都可以用相同的函数(方法)来查询和获取数据 。PDO不提供数据库抽象层;它不会重写 SQL,也不会模拟缺失的特性 。如果需要的话,应该使用一个成熟的抽象层 。
从 PHP 5.1开始附带了 PDO,在 PHP 5.0 中是作为一个 PECL 扩展使用 。PDO 需要PHP 5核心的新OO特性,因此不能在较早版本的 PHP 上运行 。
关于php数据访问对象和php访问数据库的方式的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。

    推荐阅读