php数据库之mysql connect create insert select

免费的 MySQL 数据库通常是通过 PHP 来使用的。

连接到一个 MySQL 数据库

在您能够访问并处理数据库中的数据之前,您必须创建到达数据库的连接。

在 PHP 中,这个任务通过 mysql_connect() 函数完成。

语法
mysql_connect(servername,username,password);

参数 
描述

servername 
可选。规定要连接的服务器。默认是 "localhost:3306"。

username 
可选。规定登录所使用的用户名。默认值是拥有服务器进程的用户的名称。

password 
可选。规定登录所用的密码。默认是 ""。

注释:虽然还存在其他的参数,但上面列出了最重要的参数。请访问 W3School 提供的 PHP MySQL 参考手册,获得更多的细节信息。

例子

在下面的例子中,我们在一个变量中 ($con) 存放了在脚本*稍后使用的连接。如果连接失败,将执行 "die" 部分:

<?php
$con = mysql_connect("localhost","root","123456");
if (!$con)
  {
  die('Could not connect: ' . mysql_error());
  }

// some code

?>

关闭连接

脚本一结束,就会关闭连接。如需提前关闭连接,请使用 mysql_close() 函数。

<?php
$con = mysql_connect("localhost","root","123456");
if (!$con)
  {
  die('Could not connect: ' . mysql_error());
  }

// some code

mysql_close($con);
?>

创建数据库

CREATE DATABASE 语句用于在 MySQL 中创建数据库。

语法
CREATE DATABASE database_name

为了让 PHP 执行上面的语句,我们必须使用 mysql_query() 函数。此函数用于向 MySQL 连接发送查询或命令。

例1:在下面的例子中,我们创建了一个名为 "my_db" 的数据库

展示了如何创建一个名为 "Persons" 的表,此表有三列。列名是 "FirstName", "LastName" 以及 "Age"

<?php 
$con = mysql_connect("localhost","root","123456"); 
if (!$con) 
  { 
  die('Could not connect: ' . mysql_error()); 
  }

// Create database 
if (mysql_query("CREATE DATABASE myb",$con)) 
  { 
  echo "Database created"; 
  } 
else 
  { 
  echo "Error creating database: " . mysql_error(); 
  }

// Create table in my_db database 
mysql_select_db("myb", $con); 
$sql = "CREATE TABLE Persons 

FirstName varchar(15), 
LastName varchar(15), 
Age int 
)"; 
mysql_query($sql,$con);

mysql_close($con); 
?>

 

php数据库之mysql connect create insert select

php数据库之mysql connect create insert select

php数据库之mysql connect create insert select

例2:插入数据 php insert

INSERT INTO 语句用于向数据库表中插入新记录。

向数据库表插入数据

INSERT INTO 语句用于向数据库表添加新记录。

语法
INSERT INTO table_name
VALUES (value1, value2,....)

您还可以规定希望在其中插入数据的列:

INSERT INTO table_name (column1, column2,...)
VALUES (value1, value2,....)

注释:SQL 语句对大小写不敏感。INSERT INTO 与 insert into 相同。

为了让 PHP 执行该语句,我们必须使用 mysql_query() 函数。该函数用于向 MySQL 连接发送查询或命令。

例子

在前面的章节,我们创建了一个名为 "Persons" 的表,有三个列:"Firstname", "Lastname" 以及 "Age"。我们将在本例中使用同样的表。下面的例子向 "Persons" 表添加了两个新记录:

<?php 
$con = mysql_connect("localhost","root","123456"); 
if (!$con) 
  { 
  die('Could not connect: ' . mysql_error()); 
  }

mysql_select_db("myb", $con);

mysql_query("INSERT INTO Persons (FirstName, LastName, Age) 
VALUES ('jiping', 'Guo', '23')");

mysql_query("INSERT INTO Persons (FirstName, LastName, Age) 
VALUES ('Lu', 'Guo', '24')");

mysql_close($con); 
?>

php数据库之mysql connect create insert select

例3:把来自表单的数据插入数据库

现在,我们创建一个 HTML 表单,这个表单可把新记录插入 "Persons" 表。

这是这个 HTML 表单:

php数据库之mysql connect create insert select

php数据库之mysql connect create insert select

当用户点击上例中 HTML 表单中的提交按钮时,表单数据被发送到 "insert.php"。"insert.php" 文件连接数据库,并通过 $_POST 变量从表单取回值。然后,mysql_query() 函数执行 INSERT INTO 语句,一条新的记录会添加到数据库表中。

php数据库之mysql connect create insert select

php数据库之mysql connect create insert select

查数据库:

php数据库之mysql connect create insert select

添加成功!

例3:php select

SELECT 语句用于从数据库中选取数据。

从数据库表中选取数据

SELECT 语句用于从数据库中选取数据。

语法
SELECT column_name(s) FROM table_name

注释:SQL 语句对大小写不敏感。SELECT 与 select 等效。

为了让 PHP 执行上面的语句,我们必须使用 mysql_query() 函数。该函数用于向 MySQL 发送查询或命令。

例子

下面的例子选取存储在 "Persons" 表中的所有数据(* 字符选取表中所有数据):

<?php 
$con = mysql_connect("localhost","root","123456"); 
if (!$con) 
  { 
  die('Could not connect: ' . mysql_error()); 
  }

mysql_select_db("myb", $con);

$result = mysql_query("SELECT * FROM Persons");

while($row = mysql_fetch_array($result)) 
  { 
  echo $row['FirstName'] . " " . $row['LastName']; 
  echo "
"; 
  }

mysql_close($con); 
?>

上面这个例子在 $result 变量中存放由 mysql_query() 函数返回的数据。接下来,我们使用 mysql_fetch_array() 函数以数组的形式从记录集返回第一行。每个随后对 mysql_fetch_array() 函数的调用都会返回记录集中的下一行。 while loop 语句会循环记录集中的所有记录。为了输出每行的值,我们使用了 PHP 的 $row 变量 ($row['FirstName'] 和 $row['LastName'])。

php数据库之mysql connect create insert select

用表格呈现:

php数据库之mysql connect create insert select

php数据库之mysql connect create insert select



本文转自 gjp0731 51CTO博客,原文链接:http://blog.51cto.com/guojiping/1286624