PHP MySQL 数据库 -- 学习笔记

PHP MySQL 数据库
1、创建数据库链接
注释:要想链接到一个数据库,首先,必须创建到达数据库的连接,创建函数:mysql_connect()

语法:mysql_connect(servername,username,password);
相关参数:
1、servername : 可选。规定要连接的服务器。默认是 "localhost:3306"。
2、username : 可选。规定登录所使用的用户名。默认值是拥有服务器进程的用户的名称。
3、password : 可选。规定登录所用的密码。默认是 ""。

<?php
$con = mysql_connect("localhost","peter","abc123"); //目标服务器,用户名,密码
if (!$con) {
  die('Could not connect: ' . mysql_error()); //如果链接失败,则知心话 die() 部分
}
//脚本一结束,就会关闭连接。如需提前关闭连接,请使用 mysql_close() 函数。
mysql_close($con);
?>

2、创建数据库
CREATE DATABASE 语句用于在 MySQL 中创建数据库。
语法:CREATE DATABASE database_name

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

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

if (mysql_query("CREATE DATABASE my_db",$con)) { // 创建了一个名为 "my_db" 的数据库
  echo "Database created";
} else {
  echo "Error creating database: " . mysql_error();
}

mysql_close($con);  //关闭链接
?>

3、创建表
CREATE TABLE 用于在 MySQL 中创建数据库表。

语法:
CREATE TABLE table_name (
column_name1 data_type,
column_name2 data_type,
column_name3 data_type,
.......
)
注释:为了执行此命令,我必须向 mysql_query() 函数添加 CREATE TABLE 语句。

<?php
$con = mysql_connect("localhost","peter","abc123"); //创建链接
if (!$con) {
  die('Could not connect: ' . mysql_error());
}

if (mysql_query("CREATE DATABASE my_db",$con)) { //创建名为 my_db 的数据库
  echo "Database created";
} else {
  echo "Error creating database: " . mysql_error();
}

mysql_select_db("my_db", $con); //通过 mysql_select_db() 函数选取目标数据库。
$sql = "CREATE TABLE Persons  ( //创建表
  FirstName varchar(15), //必须规定字段的最大长度 (15)
  LastName varchar(15), //必须规定字段的最大长度 (15)
  Age int
)";
mysql_query($sql,$con); //为了执行创建命令,必须向 mysql_query() 函数添加 CREATE TABLE 语句。

mysql_close($con); //关闭链接
?>
注释:当您创建 varchar 类型的数据库字段时,必须规定该字段的最大长度,例如:varchar(15)。
PHP数据库创建表时的可用数据类型.png

4、主键字段 和 自动递增字段

每一个表都应该有一个主键字段。
主键用于对表中的行进行唯一标识。每个主键值在表中必须是唯一的。
主键字段不能为空,这是由于数据库引擎需要一个值来对记录进行定位。
主键字段永远要被编入索引。
必须对主键字段进行索引,这样数据库引擎才能快速定位给予该键值的行。

//主键字段通常是 ID 号,且通常使用 AUTO_INCREMENT 设置。
//AUTO_INCREMENT 会在新记录被添加时逐一增加该字段的值。
//要确保主键字段不为空,我们必须向该字段添加 NOT NULL 设置。
$sql = "CREATE TABLE Persons  (
  personID int NOT NULL AUTO_INCREMENT, 
  PRIMARY KEY(personID), //把 personID 字段设置为主键字段。
  FirstName varchar(15),
  LastName varchar(15),
  Age int
)";
mysql_query($sql,$con);

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

语法:
INSERT INTO table_name (相关参数一,相关参数二,...)
VALUES (value1, value2,....)

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

<?php
$con = mysql_connect("localhost","peter","abc123"); //创建数据库链接
if (!$con) {
  die('Could not connect: ' . mysql_error());
}

if (mysql_query("CREATE DATABASE my_db",$con)) { //创建名为 my_db 的数据库
  echo "Database created";
} else {
  echo "Error creating database: " . mysql_error();
}

mysql_select_db("my_db", $con); //通过 mysql_select_db() 函数选取目标数据库。

mysql_query("INSERT INTO Persons (FirstName, LastName, Age)  //向Persons 的表中插入数据
VALUES ('Peter', 'Griffin', '35')");

mysql_query("INSERT INTO Persons (FirstName, LastName, Age) //向Persons 的表中插入数据
VALUES ('Glenn', 'Quagmire', '33')");

mysql_close($con); //关闭数据库链接
?>
为了让 PHP 执行该语句,我们必须使用 mysql_query() 函数。该函数用于向 MySQL 连接发送查询或命令。

6、将表单中的数据插入数据库

表单:
<html>
<body>

<form action="insert.php" method="post">
Firstname: <input type="text" name="firstname" />
Lastname: <input type="text" name="lastname" />
Age: <input type="text" name="age" />
<input type="submit" />
</form>

</body>
</html>

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

"insert.php" 页面的代码如下:
<?php
$con = mysql_connect("localhost","peter","abc123");
if (!$con) {
  die('Could not connect: ' . mysql_error());
}

if (mysql_query("CREATE DATABASE my_db",$con)) { //创建名为 my_db 的数据库
  echo "Database created";
} else {
  echo "Error creating database: " . mysql_error();
}

mysql_select_db("my_db", $con); //选定目标数据库

$sql="INSERT INTO Persons (FirstName, LastName, Age) //插入数据
VALUES('$_POST[firstname]','$_POST[lastname]','$_POST[age]')";

if (!mysql_query($sql,$con)) {
  die('Error: ' . mysql_error());
}
echo "1 record added";

mysql_close($con)
?>

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

语法:SELECT column_name(s) FROM table_name
注释:SQL 语句对大小写不敏感。SELECT 与 select 等效。

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

mysql_select_db("my_db", $con);

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

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

mysql_close($con);
?>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,875评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,569评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,475评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,459评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,537评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,563评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,580评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,326评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,773评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,086评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,252评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,921评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,566评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,190评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,435评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,129评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,125评论 2 352

推荐阅读更多精彩内容

  • MySQL 数据库常用命令 1、MySQL常用命令 create database name; 创建数据库 use...
    55lover阅读 4,784评论 1 57
  • 1.MySQL数据库 2.SQL语句 第一节课 ###1(MySQL数据库)数据库概念.avi 5...
    码了个农啵阅读 1,198评论 1 16
  • 什么是数据库? 数据库是存储数据的集合的单独的应用程序。每个数据库具有一个或多个不同的API,用于创建,访问,管理...
    chen_000阅读 4,035评论 0 19
  • 1.MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品。My...
    黄花菜已凉阅读 4,567评论 3 60
  • 文/阿丝蕾 图/优美图 十六岁的黎的世界在两具棺材掩埋于尘土后分崩离析,挖了两天两夜土坑的他,疲惫不堪,...
    阿丝蕾阅读 302评论 2 0