PHP入门 – PHP连接并操作MySQL数据库

本节文章主要介绍使用mysql_connect()函数连接数据库,同时使用mysql_*相关函数操作数据库。

关于mysql_*函数以及对应的mysql扩展库有以下说明:

PHP5中使用mysql_connect()函数进行连接,但是从PHP5.5开始,MySQL就不推荐使用了,属于废弃函数。

PHP7中已经彻底不支持了,根据官网说明,取而代之的是如下两个:mysql扩展自 PHP 5.5.0 起已废弃,并在将来会被移除。应使用 MySQLi 或 PDO_MySQL 扩展来替换之。

具体用法和说明请参考: http://php.net/manual/zh/mysqlinfo.api.choosing.php

用以替代本函数的有:mysqli_connect()  PDO::__construct()

使用时,不要在使用mysql_connect了,可以换用mysqli_connect(),用法基本类似吧,据说是面向对象的库。

PHP连接MySQL数据库

1.连接MySQL数据库服务器

通过PHP脚本程序去管理MySQL服务器中的数据,也必须先建立连接,然后才能通过PHP中的函数向服务器中发送SQL查询语句。PHP可以通过MySQL功能模块去连接MySQL服务器,办法是调用mysql_connect()函数,和使用MySQL客户机程序连接MySQL服务器类似。

resource mysql_connect ( [string server [, string username [, string password [, bool new_link [, int client_flags]]]]] )

2.判断是否连接正确

我们也可以使用两个函数来判断,mysql_errno()和mysql_error(),这两个函数分别返回上次MySQL发生的错误号和错误信息,如果未发生任何错误,mysql_errno()函数将返回0.所以,我们可以使用判断来进行处理:

int mysql_errno ([ resource $link_identifier ] )

string mysql_error ([ resource $link_identifier ] )

if(mysql_errno()){ exit(‘数据库连接错误!’.mysql_error()); }

3.选择数据库

通常数据库的创建工作都是先由数据库管理员(DBA)建立,再由PHP程序员在脚本中使用。在使用PHP脚本建立起与MySQL服务器的连接之后,为了避免每次调用PHP的mysql扩展函数时都指定目标数据库,最好先用mysql_select_db()函数为后续操作选定一个默认数据库,这个函数和SQL命令“USE bookstore”功能相似。

bool mysql_select_db ( string $database_name [, resource $ link_identifier ] )

4.设置字符集

为了避免读取和写入数据时发生数据乱码,除了要将文件格式设置为utf-8无bom头格式,还要将数据库客户端字读集设置为utf8,所以我们需要在发送sql语句之前,使用mysql_set_charset()函数来完成数据库字符集的设定!

bool mysql_set_charset ( string $charset [, resource $link_identifier = NULL ] )

5.准备SQL语句

设置字符集完毕之后,我们需要为读取或写入数据设计SQL语句字符串,例如: $sql = “select username,password from user”;

6.发送SQL语句到MySQL服务器

设计好SQL语句之后,我们使用函数mysql_query()函数,将SQL语句发送到MySQL数据库服务器,由MySQL数据库服务器来执行此SQL语句,这里注意,我们之所以将SQL语句赋值给一个变量是为了出现错误的时候便于排错,我们可以直接输出$sql这个变量。

int/resource mysql_query ( string $query [, resource $link_identifier ] )

处理结果集

将SQL语句发送到MySQL服务器之后,MySQL服务器会将执行SQL语句之后的结果返回给PHP端,这里的结果分为两种:

1.布尔型

2.结果集资源类型

当我们执行的SQL语句是DML语句,也就是增,删,改三种语句,这时mysql_query()返回的类型是布尔类型,执行成功返回真,失败返回假,但有时SQL语句执行成功,但不一定有受影响行数,所以我们可以使用mysql_affected_rows()函数返回受影响行数;

当我们执行的是DQL语句,也就是查询语句,mysql_query()函数将返回的是结果集资源类型,我们可以使用mysql_num_rows($result)函数来获取结果集当中的记录条数,但是我们无法将结果集资源当中的数据得到,因此PHP为我们提供了4个函数,来解析此结果集资源:

1.mysql_fetch_array() 返回索引和关联的混合数组

2.mysql_fetch_assoc() 返回关联数组

3.mysql_fetch_row() 返回索引数组

4.mysql_fetch_object() 返回一个对象

如果没有特殊要求,尽量不要去使用mysql_fetch_array()方法。使用mysql_fetch_row()或mysql_fetch_assoc()函数实现相同的功能,效率会更高一些。上述四个函数每执行一次,结果集资源的指针都将向后移动一位,直到最后一位,将返回布尔类型的FALSE,因此,我们可以使用条件型循环while配合上述四个函数来使用,以mysql_fetch_assoc()函数为例,如下所示:

while($row=mysql_fetch_assoc($result)){

//$row为一条记录的数组

}

取得前一次 MySQL 操作所影响的记录行数

int mysql_affected_rows ([ resource $link_identifier ] )

取得上一步 INSERT 操作产生的 ID

int mysql_insert_id ([ resource $link_identifier ] )

取得结果集中字段的数目

int mysql_num_fields ( resource $result )

取得结果数据

mixed mysql_result ( resource $result , int $row [, mixed $field ] )

PHP会把结果数据表一直保存到PHP脚本执行结束,如果必须提前释放某次查询的结果数据表,就可使用mysql_free_result()函数提前释放它,最后将数据库连接关闭掉,我们使用mysql_close()函数来完成。

bool mysql_free_result ( resource $result )

bool mysql_close ([ resource $link_identifier ] )

以下是完整示例

//连接数据库
$host = 'localhost';
$datebase = 'phplearn';
$db_username = 'root';
$db_password = '';
$db = mysql_connect($host,$db_username,$db_password);
if(mysql_errno()){
	exit('数据库连接失败!'.mysql_error());
}
mysql_select_db($datebase, $db);
mysql_set_charset('utf8', $db);

//SQL查询语句
$sql = 'SELECT id,username,tel FROM users';
$result = mysql_query($sql, $db);
while($row = mysql_fetch_assoc($result)){
	echo $row['username'].'--'.$row['tel'].'<br>';
}
echo mysql_affected_rows($db).'<br>';

//SQL插入/修改/删除语句
$sql = "INSERT INTO users(username,tel) VALUES('bosheng',15189856231)";
$result = mysql_query($sql, $db);
if($result == true){
	echo '插入成功!'.'<br>';
}

echo mysql_insert_id($db);

mysql_free_result($result);
mysql_close($db);

 

暂无评论

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇