实验六 PHP中的数据库操作和字符串操作
实验目的:
掌握PHP中数据库的基本操作,包括数据库的创建,数据表的创建,信息的增加,删除,修改,查询等操作。
掌握PHP中字符串相关函数的应用
实验内容:
1、 数据库的基本操作(创建一个学生数据库,要求写在.php文件中编写代码,通过执行php文件实现)
1) 创建数据库
<?php
$conn = mysql_connect("localhost", "root", "wwj");
//判断数据库是否存在
if(!$conn)
{
die('Could not connect:'.mysql_error());
}
//创建数据库
if(mysql_query("create database stu_db",$conn))
{
echo "Database created";
}
else
{
echo "Error created Database:".mysql_error();
}
mysql_close($conn);
?>
2) 创建数据库表(三张表:学生表(学号,姓名,性别,年龄,出生日期等,学号为主键),课程(课程号,课程名,学生,课程号为主键)和分数(学号,姓名,分数,学号和姓名为主键)
<?php
$conn = mysql_connect("localhost","root", "wwj");
//判断数据库连接是否存在
if (!$conn)
{
die('Could not connect: ' . mysql_error());
}
//选择数据库
mysql_select_db("stu_db",$conn);
$sql = "create table Student(
StuNumber varchar(10),
StuName varchar(20),
StuSex char(1),
StuAge int,
Stubirth date,
primary key(StuNumber)
)";
mysql_query($sql, $conn);
$sql = "create table Course(
CourseNumber varchar(10),
CourseName varchar(20),
Coursexuefen int,
primary key(CourseNumber)
)";
mysql_query($sql, $conn);
$sql = "create table Grade(
StuNumber varchar(10),
CourseNumber varchar(10),
CourseGrade int,
primary key(StuNumber,CourseNumber)
)";
mysql_query($sql, $conn);
?>
3) 分别在三张表中插入数据(两种插入数据的方式,一种是直接在php文件中执行sql插入语句,第二种方式是通过html页面填写需要插入到数据库中的信息,然后将信息插入到数据库中,运用这两种方式后,都要检查是否将记录成功插入到数据库中)
<?php
$conn = mysql_connect("localhost","root","wwj");
//判断数据库连接是否存在
if (!$conn)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("stu_db", $conn);
$sql = ("INSERT INTO student (StuNumber, StuName,StuSex, StuAge,Stubirth)
VALUES ('2100000003', 'zhang', '1',20, '19000304')");
mysql_query($sql,$conn);
$sql1 = ("INSERT INTO course (CourseNumber, CourseName,Coursexuefen)
VALUES ('00003', 'computer', 3)");
mysql_query($sql1,$conn);
$sql2 = ("INSERT INTO grade (StuNumber ,CourseNumber,CourseGrade)
VALUES ('2100000001', '00003', 90)");
mysql_query($sql2,$conn);
mysql_close($conn);
?>
<html>
<body>
<form action="" method="post">
学号: <input type="text" name="StuNumber" />
姓名: <input type="text" name="StuName" />
性别: <input type="text" name="StuSex" />
年龄: <input type="text" name="StuAge" />
出生日期: <input type="text" name="Stubirth" />
<input type="submit" value="提交" />
</form>
</body>
</html>
<?php
$conn = mysql_connect("localhost","root","wwj");
//判断数据库连接是否存在
if (!$conn)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("stu_db", $conn);
$sql="INSERT INTO student(StuNumber, StuName,StuSex, StuAge,Stubirth)VALUES('$_POST[StuNumber]','$_POST[StuName]','$_POST[StuSex]','$_POST[StuAge]','$_POST[Stubirth]')";
if (!mysql_query($sql,$conn))
{ die('Error: ' . mysql_error()); }
echo "1 record added";
mysql_close($conn);
?>
4) 将数据库的信息在页面中显示出来
<?php
$conn = mysql_connect("localhost","root","wwj");
//判断数据库连接是否存在
if (!$conn)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("stu_db", $conn);
$result = mysql_query("SELECT * FROM student");
echo "<table border='1'>
<tr><th>学号</th><th>姓名</th><th>性别</th><th>年龄</th><th>出生日期</th></tr>";
while($row = mysql_fetch_array($result))
{
echo "<tr>";
echo "<td>" . $row['StuNumber'] . "</td>";
echo "<td>" . $row['StuName'] . "</td>";
echo "<td>" . $row['StuSex'] . "</td>";
echo "<td>" . $row['StuAge'] . "</td>";
echo "<td>" . $row['Stubirth'] . "</td>";
echo "</tr>";
}
echo "</table>";
mysql_close($conn);
?>
5) 显示一个学生的学号,姓名,课程,课程学分和成绩
<?php
$conn = mysql_connect("localhost","root","wwj");
//判断数据库连接是否存在
if (!$conn)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("stu_db", $conn);
$result = mysql_query("SELECT Student.StuNumber,Student.StuName,Course.CourseName,Course.Coursexuefen,Grade.CourseGrade FROM Student,Course,Grade where Student.StuNumber=Grade.StuNumber and Course.CourseNumber=Grade.CourseNumber ");
echo "<table border='1'>
<tr><th>学号</th><th>姓名</th><th>课程名</th><th>学分</th><th>分数</th></tr>";
while($row = mysql_fetch_array($result))
{
echo "<tr>";
echo "<td>" . $row['StuNumber'] . "</td>";
echo "<td>" . $row['StuName'] . "</td>";
echo "<td>" . $row['CourseName'] . "</td>";
echo "<td>" . $row['Coursexuefen'] . "</td>";
echo "<td>" . $row['CourseGrade'] . "</td>";
echo "</tr>";
}
echo "</table>";
mysql_close($conn);
?>
6) 更新和删除数据库中的记录
<?php
$conn = mysql_connect("localhost","root","wwj");
//判断数据库连接是否存在
if (!$conn)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("stu_db", $conn);
$sql = ("UPDATE student SET StuAge=22 WHERE StudentNumber='2100000003'");
//$sql = ("DELETE FROM student WHERE StudentNumber='2100000001'");
$row=mysql_query($sql,$conn);
mysql_close($conn);
?>
2、正则表达式的使用:设计一个PHP网页,其中验证表单数据的正确性,表单数据中包括用户名、密码、出生年月、E-mail。要求用户名为6-12个字符,密码为5-10数字,出生年月为有效的日期,E-mail为有效的Email地址。在服务器端进行验证。
提示:
1)preg_match() — 执行一个正则表达式匹配
int preg_match ( string $pattern , string$subject [, array &$matches [, int $flags = 0 [, int $offset = 0 ]]] )
pattern 要搜索的模式,字符串类型。
subject 输入字符串。
matches 如果提供了参数matches,它将被填充为搜索结果。 $matches[0]将包含完整模式匹配到的文本, $matches[1] 将包含第一个捕获子组匹配到的文本,以此类推。
例子:
preg_match("/^[A-Z]{10}$/",$e);// 确定e变量的内容是否为10个大写字母。
2)正则表达式:
正则表达式的形式一般如下:
/*******/
其中位于“/”定界符之间的部分就是将要在目标对象中进行匹配的模式。
表1.常用的元字符 | |
代码 | 说明 |
. | 匹配除换行符以外的任意字符 |
\w | 匹配字母或数字或下划线或汉字 |
\s | 匹配任意的空白符 |
\d | 匹配数字 |
\b | 匹配单词的开始或结束 |
^ | 匹配字符串的开始 |
$ | 匹配字符串的结束 |
表2.常用的限定符 | |
代码/语法 | 说明 |
* | 重复零次或更多次 |
+ | 重复一次或更多次 |
? | 重复零次或一次 |
{n} | 重复n次 |
{n,} | 重复n次或更多次 |
{n,m} | 重复n到m次 |
较为常用的定位符包括: “^”, “$”, “\b” 以及“\B”。
“^”定位符规定匹配模式必须出现在目标字符串的开头,
“$”定位符规定匹配模式必须出现在目标对象的结尾
“|”,相当于OR操作:
[ ]符号表示可选的内容
例子:
/^\w+/ :匹配一行的第一个单词(或整个字符串的第一个单词,具体匹配哪个意思得看选项设置)
/fo+/
因为上述正则表达式中包含“+”元字符,表示可以与目标对象中的 “fool”, “fo”, 或者 “football”等在字母f后面连续出现一个或多个字母o的字符串相匹配。
/jim{2,6}/
上述正则表达式规定字符m可以在匹配对象中连续出现2-6次,因此,上述正则表达式可以同jimmy或jimmmmmy等字符串相匹配。
/^hell/:字符串开头要是hell。
/ar$/:与目标对象中以“car”, “bar”或 “ar” 结尾的字符串相匹配。
“/(b|cd)ef/”: 匹配含有“bef”或者 “cdef”的字符串;
/[A-Z]/
从A到Z范围内任何一个大写字母相匹配。
3)弹出错误提示框的代码方法:
例子:
echo "<script>alert('Email格式错');</script>";
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=gb2312">
</head>
<body>
<form action="" method="post">
<table width="60%" border="1">
<tr>
<td width="10%">用户名</td>
<td width="50%"> <input type="text" name="userid" size="20"></td>
<td width="40%">* 6~12个字符(数字,字母和下划线)</td>
</tr>
<tr>
<td >密码</td>
<td > <input type="text" name="pwd" size="20"></td>
<td >* 5~10数字</td>
</tr>
<tr>
<td >出生年月</td>
<td > <input type="text" name="birthday" size="20"></td>
<td >* 格式:YYYY-MM-DD</td>
</tr>
<tr>
<td >E-mail:</td>
<td > <input type="text" name="email" size="20"></td>
<td >* </td>
</tr>
<tr>
<td></td>
<td><input type="submit" name="confirm" value="确定"></td>
</tr>
</table>
</form>
<?php
if(isset($_POST['confirm']))
{
$userid=$_POST['userid'];
$pwd=$_POST['pwd'];
$birthday=$_POST['birthday'];
$email=$_POST['email'];
/* $userid="gdfghkdfhg";
$pwd="894676";
$birthday="4567-12-05";
$email="fsjdhgj@hgsjdg";
*/
if(!preg_match("/^\w{6,12}$/",$userid))
{
echo "<script>alert('用户名格式错');</script>";
}
if(!preg_match("/^\d{5,10}$/",$pwd))
{
echo "<script>alert('密码格式错');</script>";
}
if(!preg_match("/^\d{4}-(0\d|1[0-3])-([012]\d|[3][01])$/",$birthday))
{
echo "<script>alert('出生日期格式错');</script>";
}
if(!preg_match("/^[\w-]+@[\w-.]+$/",$email))
{
echo "<script>alert('Email格式错');</script>";
}
}
?>
</body>
</html>