php和数据库基础知识,PHP和数据库基础知识

PHP 大小写敏感

在 PHP 中,所有用户定义的函数、类和关键词(例如 if、else、echo 等等)都对大小写不敏感。不过在 PHP 中,所有变量都对大小写敏感。

在下面的例子中,所有这三条 echo 语句都是合法的(等价):

1e534030ed8a6f090a7070f36eceb252.png

在下面的例子中,只有第一条语句会显示 $color 变量的值(这是因为 $color、$COLOR 以及 $coLOR 被视作三个不同的变量):

eeb741680b2368940ef14d47cc522d4f.png

PHP 变量规则:

变量以 $ 符号开头,其后是变量的名称

变量名称必须以字母或下划线开头,不能以数字开头

变量名称只能包含字母数字字符和下划线(A-z、0-9 以及 _)

变量名称对大小写敏感($y 与 $Y 是两个不同的变量)

PHP 是一门类型松散的语言

PHP 没有创建变量的命令,变量会在首次为其赋值时被创建,PHP 根据它的值,自动把变量转换为正确的数据类型。

PHP static 关键词

通常,当函数完成/执行后,会删除所有变量。不过,有时我需要不删除某个局部变量。要实现这一点需要,请在首次声明变量时使用 static 关键词:

90bea609316e8fbcc62c1c64ccfde17c.png

运行结果:0,1,2,3,4

每当函数被调用时,这个变量所存储的信息都是函数最后一次被调用时所包含的信息。

注释:该变量仍然是函数的局部变量。

PHP 数组

在 PHP 中,有三种类型的数组:

数值数组 - 带有数字 ID 键的数组

关联数组 - 带有指定的键的数组,每个键关联一个值

多维数组 - 包含一个或多个数组的数组

PHP 数值数组

这里有两种创建数值数组的方法:

自动分配 ID 键(ID 键总是从 0 开始):

$cars=array("Volvo","BMW","Toyota");

人工分配 ID 键:

$cars[0]="Volvo";

$cars[1]="BMW";

$cars[2]="Toyota";

PHP 关联数组

关联数组是使用您分配给数组的指定键的数组。

这里有两种创建关联数组的方法:

$age=array("Peter"=>"35","Ben"=>"37","Joe"=>"43");

或者:

$age['Peter']="35";

$age['Ben']="37";

$age['Joe']="43";

PHP count() 函数

7c1bf422aa17bd090fb291e7ea5cfaa7.png

遍历关联数组

遍历并打印关联数组中的所有值,您可以使用 foreach 循环,如下所示:

f44eeee4f15846bb036e70a1b20ee289.png

foreach 语法结构提供了遍历数组的简单方式,有两种语法:

2c27ccf42695b6dcebf64b9e7ab356d5.png

第一种格式遍历给定的 array_expression 数组。每次循环中,当前单元的值被赋给 $value 并且数组内部的指针自动向前移一步(因此下一次循环中将会得到下一个单元)。

第二种格式做同样的事,只除了当前单元的键名也会在每次循环中被赋给变量 $key。

PHP exit() 函数

exit() 函数输出一条消息,并退出当前脚本。

该函数是 die() 函数的别名。

d398c0b8747607f1239e36d5d70c62dd.png

php中使用pdo访问sqlite3

1.PDO简介

PDO是 PHP Date Object (PHP数据对象)的简称,它是与 PHP5.1版本一起发行的,在 PHP 6 中默认使用PDO连接数据库,所有非 PDO扩展将会在 PHP 6中被移除,该扩展提供PHP内置类 PDO来对数据库进行访问,不同数据库使用相同的方法名,从而解决数据库连接不统一的问题。

在 Windows 环境下,如果要想其支持某个具体的数据库,那么还要记载对应的数据库选项,比如,要支持 sqlite 数据库,则还需要加载“extension=php_pdo_sqlite.dll”选项。

从php5 >=5.3.0 的时候开始默认支持sqlite3,可用phpinfo()进行检查确认

2.PDO构造函数连接数据库

在PDO中,要建立数据库的连接需要实例化 PDO 的构造函数,PDO构造函数的语法格式如下:

_construct(string $dsn[,string $username[,string $password[,array $driver_options]]])

其中:

dsn:数据源名称,包括主机名端口号和数据库名称。

username:连接数据库的用户名。

password:连接数据库的密码。

driver_options:连接数据库的其它选项。

用实例讲解,通过PDO连接 MySQL 数据库,具体代码如下:

7ebf5d8ccd4f773476ccf6ff4d7ec869.png

3.DSN详解

DSN是Data Source Name(数据源名称)的首字母缩写。DSN提供连接数据库需要的信息。PDO的DSN包括3部分:PDO驱动名称(如:mysql、sqlite或者pgsql)、冒号和驱动特定的语法。每种数据库都有其特定的驱动语法。

在使用不同的数据库时,必须明确数据库服务器是完全独立与 PHP 的,是实体。但是在实际的情况可能是数据库服务器与 Web服务器不在同一台计算上,此时需要通过PDO连接数据库时,就修改DSN中的主机名称。

由于数据库服务器只是特定的端口上监听连接请求。每种数据库服务器具有一个默认的端口号(MySQL 是3306),但是数据库管理员可以对端口号进行修改,因此有可能 PHP找不到数据库的端口号,此时就可以在 DSN中包含端口号。比如:

$dsn="mysql:host=127.0.0.1;port=3310;dbname=admin";

由于一个数据库中可能同时拥有多个数据库,所以通过DSN连接数据库时,通常都包括数据库名称,这样可以

确保连接的是用户想要的数据库,而不是其他的数据库了!

4.PDO中执行SQL语句的三种方法

可以使用三种方式来执行SQL语句,分别是 exec()方法,query方法,以及预处理语句prepare()和execute()方法~

4.1exec()方法

返回执行SQL 语句后受影响的行数,其语法格式如下:

int PDO::exec(string statement)

参数 satatement 是要执行的SQL语句,该方法返回执行SQL 语句时受影响的行数,通常用于 INSERT,DELETE和UPDATE语句中。用具体代码讲解如下:

e94cd24cfef694a3a54622ef9cf06602.png

4.2query()方法

返回执行查询后的结果集,该函数的语法格式如下:

PDOStatement PDO::query(string statement)

参数 satatement 是要执行的 SQL语句,它返回的是一个PODStatement对象!具体请看下面示例代码:

a025fe9eefaff6d63b0e6e6c59a52710.png

注意:

a、query和exec都可以执行所有的sql语句,只是返回值不同而已。

b、query可以实现所有exec的功能。

c、当把select语句应用到 exec 时,总是返回 0

d、如果要看查询的具体结果,可以通过foreach语句完成循环输出

4.3预处理语句:prepare()语句和execute()语句

预处理语句包括prepare()和execute()两种方法。首先,通过prepare()方法做查询准备工作,然后通过execute()方法执行查询,并且还可以通过bindParam()方法来绑定参数给execute()方法,语法如下:

PDOStatement PDO::prepare(string statement[,array driver_options])

bool PDOStatement::execute([array input_parameters])

fd0aa75ef6647d85b0956557e1302b1a.png

4.4PDO中获取结果集之fetch()方法详解

fetch()方法获取结果集中的下一行数据,该函数的具体语法格式如下:

mixed PDOStatement::fetch ([ int $fetch_style [, int $cursor_orientation = PDO::FETCH_ORI_NEXT [, int $cursor_offset = 0 ]]] )

参数 fetch_style:控制结果集的返回方式,其中可选择的值如下表:

ede609d2ddc6a63da5fa7d53c077e75d.png

参数 cursor_orientation:PDOStatement对象的一个滚动游标,可以获取指定的一行。

参数 cursor_offset:游标的偏移量。

下面实例通过 fetch()方法获取结果集中下一行的数据,用 while 语句完成数据库中数据的循环输出,步骤如下:

64d719f229eeb4c6618d103282e6ec06.png

学习参考PHP中文网

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值