PHP数据库 *** 作之基于Mysqli的数据库 *** 作类库

PHP数据库 *** 作之基于Mysqli的数据库 *** 作类库,第1张

此类库简单、易用,便于你自己修改和对功能的改善,能解决大部分

PHP

项目中执行的

SQL

*** 作。

初步工作

首先,请大家下载这个类库

Mclassphp 再下载一个

Mysqli

连接数据库的类库

MysqliDbclassphp(打包下载地址)

新建一个

includes

的文件夹,将下载下来的两个

class

文件,放进去。

然后,请你在项目下创建一个

testphp

文件。注:UTF-8

文件格式

请先根据你机器的情况,填充以下代码,用于连接数据库:

复制代码

代码如下:

header('Content-Type:text/html;Charset=utf-8');

define('ROOT_PATH',

dirname(__FILE__));

define('DB_HOST',

'localhost');

//数据库服务器地址

define('DB_USER',

'root');

//数据库用户名

define('DB_PWD',

'×××');//数据库密码

define('DB_NAME',

'×××');

//数据库名称

define('DB_PORT',

'3306');

//数据库端口

function

__autoload($className)

{

require_once

ROOT_PATH

'/includes/'

ucfirst($className)

'classphp';

//自动加载

class

文件

}

好了,上面的这些 *** 作都是初步工作,下面正式进入类库的讲解。

类库讲解

首先,我们得实例化

Mclassphp,实例化很简单:

复制代码

代码如下:

$m

=

new

M();

//这步 *** 作代表

Mclassphp

中的所有功能都封装在了变量

$m

注:

1、M类库中的方法参数说明,请到

Mclassphp

文件中看详细的注释,这里不再进行叙述。建议在学习的时候,对照着看下文件中的参数即注释。

2、讲解代码中用到的数据库结构为:

复制代码

代码如下:

CREATE

TABLE

`user`

(

`id`

int(8)

unsigned

NOT

NULL

auto_increment,

`name`

varchar(50)

default

NULL,

`email`

varchar(100)

default

NULL,

`age`

smallint(3)

default

NULL,

`class_id`

int(8)

default

NULL,

`commit_time`

int(10)

default

NULL,

PRIMARY

KEY

(`id`),

KEY

`name`

(`name`)

)

ENGINE=MyISAM

DEFAULT

CHARSET=utf8

复制代码

代码如下:

CREATE

TABLE

`class`

(

`class_id`

int(8)

NOT

NULL

auto_increment,

`class_name`

varchar(100)

default

NULL,

PRIMARY

KEY

(`class_id`)

)

ENGINE=InnoDB

DEFAULT

CHARSET=utf8

并添加一条测试数据。

3、M类库中,大部分方法都分两中类型,即:SQL方法;拼接方法,具体在实例中可以看出

4、以下称述中的

M

Mclassphp

文件

方法1、Insert()

添加数据

Insert

方法的全部使用案例如下:

复制代码

代码如下:

$m->Insert("user",

null,

array('焦焦',

'liruxing1715@sinacom',

'23',

time()));

//

拼接方法:往`user`表中添加一条数据,返回值为数据库影响的行数

$m->Insert("user",

null,

array('焦焦',

'liruxing1715@sinacom',

'23',

time()),

true);

//

功能同上,返回

last_insert_id(插入的增长id)

$m->Insert("INSERT

INTO

`user`

(`name`,

`email`,

`age`,

`commit_time`)

VALUES

('张小花',

'zhangxiaohua@sinacomcn',

'22',

'"time()"')");

//SQL方法,返回值为数据库影响的行数

$m->Insert("INSERT

INTO

`user`

(`name`,

`email`,

`age`,

`commit_time`)

VALUES

('张小花',

'zhangxiaohua@sinacomcn',

'22',

'"time()"')",

true);

//

同上,返回

last_insert_id

注:Insert

方法中的第二个参数若为null,可自动获得插入表除

auto_increment

字段之外的所有字段,详情请看M源文件;若要返回值为最后插入的

ID,那么请设置

Insert

方法的最后一个参数为

true(默认是false);

方法2、Update()

修改数据

update

方法的全部使用案例如下:

复制代码

代码如下:

$m->Update("user",

array('name'=>'李茹茹',

'age'=>24),

"id=1");

//拼接方法,修改id为1的数据的名称为“李茹茹”;年龄为“24”,其方法的返回值为受影响的行数

$m->Update("UPDATE

`user`

SET

`name`='李茹茹',

`age`=24

WHERE

id

=

1");

//SQL

用法,功能同上

方法3、Del()

删除数据

Del

方法的全部使用案例如下:

复制代码

代码如下:

$m->Del('user',

'id=3');

//拼接方法:删除`user`表中

id

为3的数据,返回受影响的行数

$m->Del("DELETE

FROM

`user`

WHERE

id=4");

//SQL方法:删除`user`表中

id

为4的数据,返回受影响的行数

$m->Del("DELETE

FROM

`user`

WHERE

id

in

(10,

11,

12)");

//SQL方法:删除多条数据,删除`user`表中

id

10、11、12

的数据,返回受影响的行数

方法4、Total()

获取记录数,返回值都为int

Del

方法的全部使用案例如下:

复制代码

代码如下:

$m->Total('user');

//拼接方法:返回

`user`表中的记录数,无条件

$m->Total('user',

'id>1');

//拼接方法:返回

`user`表中

id

大于1的记录数,有条件

$m->Total("SELECT

COUNT()

AS

total

FROM

`user`");

//SQL方法,注:使用SQL方法,语句中必须使用

"AS

total",否则会报错

方法5、IsExists()

检查数据是否存在,返回值为boolean

复制代码

代码如下:

$m->IsExists('user',

"`name`='焦焦'");

//拼接方法:返回`user`表中是否存在`name`为“焦焦”的数据,返回true,若不存在,返回false

方法6、InsertId()

获取表下一个添加的自动增长id,注意,这里不进行添加 *** 作,只是获取下一个增长id

复制代码

代码如下:

echo

$m->InsertId('user');

//获取`user`

表下一个添加的自动增长id

方法7、GetRow()

返回单条数据,返回值为一维数组

GetRow

方法的全部使用案例如下:

复制代码

代码如下:

$data

=

$m->GetRow("SELECT

`name`,email

FROM

`user`

WHERE

id=1");

//SQL方法,返回一维数组,例如:Array

(

[name]

=>

焦焦

[email]

=>

liruxing1715@sinacom

)

$data

=

$m->GetRow("SELECT

u`name`,

uemail,

cclass_name

FROM

`user`

u,

`class`

c

WHERE

uclass_id=cclass_id

AND

uid=1");

//SQL方法,多表查询

$data

=

$m->GetRow('user',

'`name`,email',

"id=1");

//拼接方法

$data

=

$m->GetRow('user

as

u,`class`

c',

'u`name`,uemail,cclass_name',

"uid=1

AND

uclass_id=cclass_id");

//拼接方法,多表查询

$data

=

$m->GetRow("SELECT

`name`,email

FROM

`user`");

//如果没有指定条件应该是显示全部信息,但是在此方法中将默认显示第一条(不推荐这么使用!!!)

$data

是查询出来的一维数组。

方法8、GetOne()

返回单个数据

GetOne

方法的全部使用案例如下:

复制代码

代码如下:

$name

=

$m->GetOne("SELECT

`name`

FROM

`user`

WHERE

id=1");

//SQL方法,返回一个字符串,例如:焦焦

$name

=

$m->GetOne("user",

"name",

"id=1");

//拼接方法,返回一个字符串,例如:焦焦

方法9、FetchAll()

返回所有记录

复制代码

代码如下:

$data

=

$m->FetchAll("user");

//返回`user`表中的所有记录,以二维数组的形式

$data

=

$m->FetchAll("SELECT

FROM

`user`");

//SQL

方法,功能和返回值同上

$data

=

$m->FetchAll("user",

"name,email",

"id>1",

'id

DESC',

'2');

//返回两条id>1的数据,只显示name,email,并且以id

为倒序排序。注:请注意该方法的最后一个参数也可以为'0,2',目的是为分页准备的,如果第一页为'0,2'的话,那么第二页就是'2,2'

//该方法也支持联表查询和多表查询,下面以联表查询为例

$data

=

$m->FetchAll("`user`

as

u

LEFT

JOIN

`class`

as

c

ON

uclass_id=cclass_id",

"u`name`,uemail,

cclass_name",

"uid=1");

//注意:该拼接方法中,ON

添加的位置

注:对于该

FetchAll

方法,后续我会写一篇使用该方法进行完美分页的文章!!请关注。

方法10、MultiQuery()

执行多条SQL语句

复制代码

代码如下:

$sql

=

"INSERT

INTO

user

(`name`,email,

age,

class_id,

commit_time)

VALUES

('贾花花',

'jiahuahua@sinacomcn',

'22',

'1',

'"time()"')";

//添加一个名叫“贾花花”的学生信息

$sql

=

";DELETE

FROM

`user`

WHERE

`name`='焦焦'";

//删除一条名叫“焦焦”的学生信息

//解释:$sql

是多条

SQL

以英文;(分号)拼接起来的

$data

=

$m->MultiQuery($sql);

//返回为true,代表执行成功;为false,代表执行失败

类库讲解完毕

到此该类库的全部功能就讲解完毕,希望你能多看看M文件,了解其内部运行的机制。M

文件不会存在执行缓慢情况,请大家放心使用。

如果在使用过程中出现

SQL

拼接错误,类库会报出友善的错误提示。

有问题请留言,欢迎大家的批评和建议,加油!学习好运。

一、函数依赖概念

函数依赖是从数学角度来定义的,在关系中用来刻画关系各属性之间相互制约而又相互依赖的情况。函数依赖普遍存在于现实生活中,比如,描述一个学生的关系,可以有学号、姓名、所在系等多个属性,由于一个学号对应一个且仅一个学生,一个学生就读于一个确定的系,因而当“学号”属性的值确定之后,“姓名”及“所在系”的值也就唯一地确定了,

此时,

就可以称“姓名”和“所在系”函数依赖于“学号”,或者说“学号”函数决定“姓名”和“所在系”,记作:学号→姓名、学号→所在系。下面对函数依赖给出确切的定义。

定义:设U{A1,A2,…,An}是属性集合,R(U)是U上的一个关系,x、y是U的子集。若对于R(U)下的任何一个可能的关系,

均有x的一个值对应于y的唯一具体值,称y函数依赖于x,记作x→y。

其中x称为决定因素。进而若再有y→x,则称x与y相互依赖,记作x←→y。例如表1.2所示“系”关系中:如果系名值是唯一的,即各系名均不相同,那么有函数依赖集:

系代码→系名,系代码→系地址,系代码→系电话,系代码→系专业设置。

系名→系代码,系名→系地址,系名→系电话,系名→系专业设置。

可见,系名与系代码相互依赖,记作系名←→系代码。

函数依赖中还可细分为多种函数依赖,分别介绍如下:

二、部分函数依赖

设R(U)是属性集U上的关系,x、y是U的子集,x’是x的真子集,若x→y且x’→y,则称y部分依赖x,记作X→PY。显然,当且仅当x为复合属性组时,才有可能出现部分函数依赖。

例如表16中,

显然有课程号→课程名,课程号→开课教研室代码。从另一角度看,只要课程号一定,同时课程名确定,开课教研室也就唯一确定,因此课程号+课程名→开课教研室代码。

但它与前述课程号→开课教研室代码是不同的,因为{课程号,课程名}存在真子集:“课程号”,课程号→开课教研室代码,我们把课程号十课程名→开课教研室代码称为“开课教研室代码”部分函数依赖于课程号+课程名。

三、完全函数依赖

设R(U)是属性集U上的关系,x、y是U的子集,x’是x的真子集。若对于R(U)的任何一个可能的关系,有x→y但x’→y,则称y完全函数依赖于x,记作X→FY。

所谓完全依赖是说明在依赖关系的决定项(即依赖关系的左项)中没有多余属性,有多余属性就是部分依赖。

例如设关系模式R,R=R(学号,姓名,班号,课程号,成绩),易知:

“(学号,班号,课程号)→成绩”是R的一个部分依赖关系。

因此有决定项的真子集(学号,课程号),使得“(学号,课程号)→成绩”成立,且“学号→成绩”或“课程号→成绩”成立,“(学号,课程号)→

成绩”是R的一个完全依赖关系。

四、传递函数依赖

设R(U)是属性集U上的关系,x、y、z是U的子集,在R(U)中,若x→y,但y→x,若y→z,则x→z,称z传递函数依赖于x,记作X→TZ。

例如在一个学校中,每门课均是某一位老师教,但有些老师可教多门课,则有关系“教学”如表3.1所示。

由以上关系不难分析,课程名→职工号、职工号→课程名,但职工号和其他属性的函数关系中都是决定因素,即职工号→老师名、职工号→职称,在这种情况下,老师名、职称传递函数依赖于课程名。

表3.1

教学表

课程名

职工号

老师名

性别

出生日期

职称

英语

T1

张平

55.6.3

教授

数学

T2

王文

62.10.5

副教授

C语言

T3

李迎

62.10.5

副教授

数据库

T2

王文

62.10.5

副教授

下面进一步举例说明。

例如设车间考核职工完成生产定额关系为W:

W(日期,工号,姓名,工种,定额,超额,车间,车间主任)

请画出该关系中存在的所有类型的函数依赖。

解答:因每个职工每个月超额情况不同,而定额一般很少变动,因此为了识别不同职工以及同一职工不同月份超额情况,选定“日期”与“工号”两者组合作为主关键字。为了直观醒目,可以在关系框架中的主关键字下方划一横线。

用箭头标出各属性的依赖情况,如图33所示:

图33

关系中各属性的依赖情况

图中表明:“超额”完全函数依赖于主关键字;“姓名”、“工种”和“车间”仅依赖于关键字中的“工号”;因“定额”依赖于“工种”,故“定额”传递函数依赖于“工号”;因“车间主任”函数依赖于“车间”,因而“车间主任”传递函数依赖于“工号”。

以上就是关于PHP数据库 *** 作之基于Mysqli的数据库 *** 作类库全部的内容,包括:PHP数据库 *** 作之基于Mysqli的数据库 *** 作类库、数据库中直接函数依赖和传递函数依赖的区别、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9617152.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-30
下一篇 2023-04-30

发表评论

登录后才能评论

评论列表(0条)

保存