当前位置:   article > 正文

PHP语言之MySQL操作--educoder作业_随着公司规模的扩大,老板希望能够利用数据库技术对员工与部门的信息进行管理,而这

随着公司规模的扩大,老板希望能够利用数据库技术对员工与部门的信息进行管理,而这

本文章内容为作者网上收集而来,通过测试基本无误,供大家参考,希望对大家有所帮助

第1关:PHP对MySQL的基本操作

任务描述

随着公司规模的扩大,老板希望能够利用数据库技术对员工与部门的信息进行管理,而这个任务正好落到了你的身上。你选择了PHP+MySQL的组合来完成这个任务,为了能让老板对你的工作有一个大致的了解,你准备第一步进行数据库的建立和员工以及部门信息数据的录入,并将录入的数据显示在页面中便于老板查看。为了完成这一步,你需要学习以下关于PHP与MySQL的知识。

编程要求

将右侧代码中相应的功能补全,具体要求:

  1. 实现数据库连接,其中url为'127.0.0.1',用户名'root',密码'123123'。
  2. 创建部门信息表emp_dept,包含两个属性,d_id表示部门编号,将其声明为无符号的int类型,并作为该表的主键且为自增形式。d_name表示部门名称,将其声明为varchar类型。
  3. 向部门信息表中插入以下数据: (1, '开发部'), (2, '媒体部'), (3, '人事部'),(4, '后勤部'), (5, '市场部'), (6, '运维部'), (7, '销售部')
  4. 修改用户表emp_info,将用户表 e_id int unsigned primary key auto_increment, e_name varchar(20) not null, d_name varchar(20) not null, date_of_birth timestamp not null, date_of_entry timestamp not null 中的部门名称d_name字段删除,再添加部门ID字段 d_id int unsigned not null
  5. 向用户表中添加信息: (1, '小红', 1, '2015-4-9 17:51:00', '2015-4-9 17:52:00'), (2, '李四', 5, '2008-4-3 13:33:00', '2013-10-24 17:53:00'), (3, '王五', 4, '2008-4-3 13:33:00', '2015-4-21 13:33:00'), (4, '赵六', 4, '2008-4-3 13:33:00', '2015-3-20 17:54:00'), (5, '小兰', 2, '1989-5-4 17:33:00', '2012-6-18 17:54:00'), (6, '小新', 5, '1993-9-18 17:36:00', '2015-2-28 17:36:00'), (7, '小白', 2, '1991-10-17 17:37:00', '2014-8-16 17:37:00'), (8, '小智', 7, '1987-6-20 17:37:00', '2015-1-10 17:38:00'), (9, '大头', 6, '1991-2-14 08:49:00', '2014-7-12 08:49:00'), (10, '小明', 3, '1991-2-14 08:49:00', '2015-3-4 09:10:00'), (11, '小刘', 1, '1992-3-18 14:52:00', '2014-7-21 09:00:00');
  6. 进行两个表的连接查询: 为emp_info表定义别名emp,为emp_dept表定义别名dept,通过别名来标识要获取的字段。使用left join进行左连接查询。最后需要使用on关键字标识出两个表的关联条件,即部门id。 要查询的字段有 emp.e_id,emp.e_name,emp.date_of_birth,emp.date_of_entry,dept.d_name

测评说明

平台将自动编译补全后的代码,并根据程序的输出判断是否正确。

代码如下:

  1. <?php
  2. /**
  3. * 初始化数据库连接
  4. */
  5. require 'public_function.php';
  6. //创建对象,连接数据库
  7. /*****begin*********/
  8. $link=new mysqli('127.0.0.1', 'root', '123123');
  9. /*****end*********/
  10. //判断数据库连接是否成功,如果不成功则显示错误信息并终止脚本继续执行
  11. if($link->connect_error){
  12. die('连接数据库失败!'.$link->connect_error);
  13. }
  14. //设置字符集,选择数据库
  15. $link->query("drop database if exists 'educoder';");
  16. $link->query("create database educoder;");
  17. $link->query('set names utf8;');
  18. $link->query('use educoder;');
  19. //创建部门信息表
  20. /*****begin*********/
  21. $sql="create table emp_dept (
  22. d_id int unsigned primary key auto_increment,
  23. d_name varchar(20) not null
  24. )charset=utf8;";
  25. $link->query($sql);
  26. /*****end*********/
  27. //向部门信息表中插入数据
  28. /*****begin*********/
  29. $sql="INSERT INTO emp_dept VALUES
  30. (1, '开发部'), (2, '媒体部'), (3, '人事部'),(4, '后勤部'),
  31. (5, '市场部'), (6, '运维部'), (7, '销售部');";
  32. $link->query($sql);
  33. /*****end*********/
  34. //修改用户表
  35. /*****begin*********/
  36. $sql="drop table if exists emp_info;";
  37. $link->query($sql);
  38. $sql="create table emp_info (
  39. e_id int unsigned primary key auto_increment,
  40. e_name varchar(20) not null,
  41. d_id int unsigned not null,
  42. date_of_birth timestamp not null,
  43. date_of_entry timestamp not null
  44. )charset=utf8;";
  45. $link->query($sql);
  46. /*****end*********/
  47. //向其中添加用户数据
  48. /*****begin*********/
  49. $sql="INSERT INTO emp_info VALUES
  50. (1, '小红', 1, '2015-4-9 17:51:00', '2015-4-9 17:52:00'),
  51. (2, '李四', 5, '2008-4-3 13:33:00', '2013-10-24 17:53:00'),
  52. (3, '王五', 4, '2008-4-3 13:33:00', '2015-4-21 13:33:00'),
  53. (4, '赵六', 4, '2008-4-3 13:33:00', '2015-3-20 17:54:00'),
  54. (5, '小兰', 2, '1989-5-4 17:33:00', '2012-6-18 17:54:00'),
  55. (6, '小新', 5, '1993-9-18 17:36:00', '2015-2-28 17:36:00'),
  56. (7, '小白', 2, '1991-10-17 17:37:00', '2014-8-16 17:37:00'),
  57. (8, '小智', 7, '1987-6-20 17:37:00', '2015-1-10 17:38:00'),
  58. (9, '大头', 6, '1991-2-14 08:49:00', '2014-7-12 08:49:00'),
  59. (10, '小明', 3, '1991-2-14 08:49:00', '2015-3-4 09:10:00'),
  60. (11, '小刘', 1, '1992-3-18 14:52:00', '2014-7-21 09:00:00');";
  61. $link->query($sql);
  62. /*****end*********/
  63. //左连接查询
  64. //填充下面sql语句
  65. $sql="select emp.e_id,emp.e_name,emp.date_of_birth,emp.date_of_entry,dept.d_name
  66. from emp_info as emp
  67. left join emp_dept as dept
  68. on emp.d_id = dept.d_id;";
  69. $result=$link->query($sql);
  70. $db=new Init();
  71. $emp_info =$db->fetchAll($sql);
  72. //设置常量,用以判断视图页面是否由此页面加载
  73. define('APP', 'educoder');
  74. //加载视图页面,显示数据
  75. require 'list_html.php';

第2关:PHP实现下拉菜单显示数据 上

任务描述

在添加员工信息时,一般员工所属部门是不允许用户手动输入的,而是通过动态查询数据库,获取到部门表数据,以下拉菜单的形式展示到表单中,以供选择。你的下一个任务是完成员工添加及修改时动态获取部门信息的功能。

编程要求

补全右侧代码,要求实现的功能: 1.(本关代码)补全empAdd.php文件,为实现以下拉菜单来展现部门数据做准备。 2.(下一关代码)补全update_html.php文件,下拉菜单的value为部门ID,下拉菜单的文字显示为部门名称。 其中,部门信息表都存储在数组$emp_dept中,数组的下标即为表的属性名。 表的结构如下:

  1. create table emp_dept (
  2. d_id int unsigned primary key auto_increment,
  3. d_name varchar(20) not null
  4. );

测评说明

平台将自动编译补全后的代码,并根据程序的输出判断是否正确。

代码如下:

  1. <?php
  2. /**
  3. * 初始化数据库连接
  4. */
  5. Class Init
  6. {
  7. private $link;
  8. private static $host="127.0.0.1";
  9. private static $root="root";
  10. private static $password="123123";
  11. function __construct()
  12. {
  13. $this->link=new mysqli(self::$host,self::$root,self::$password);
  14. //判断数据库连接是否成功,如果不成功则显示错误信息并终止脚本继续执行
  15. if($this->link->connect_error){
  16. die('连接数据库失败!');
  17. }
  18. //设置字符集,选择数据库
  19. $this->link->query('set names utf8;');
  20. $this->link->query('use educoder;');
  21. }
  22. /**
  23. * 执行SQL的方法
  24. * @param string $sql 待执行的SQL
  25. * @return mixed 失败返回false,成功,如果是查询语句返回结果集,如果非查询类返回true
  26. */
  27. public function query($sql) {
  28. /***********Begin******/
  29. if ($result =$this->link->query($sql)) {
  30. return $result;
  31. }else{
  32. echo 'SQL执行失败:<br>';
  33. echo '错误的SQL为:',$sql,'<br>';
  34. echo '错误的代码为:',$this->link->connect_errno,'<br>';
  35. echo '错误的信息为:',$this->link->connect_error,'<br>';
  36. return false;
  37. }
  38. /*********end*******/
  39. }
  40. /**
  41. * 处理结果集中有多条数据的方法
  42. * @param string $sql 待执行的SQL
  43. * @return array 返回遍历结果集后的二维数组
  44. */
  45. public function fetchAll($sql) {
  46. if ($result =$this->link->query($sql)) {
  47. //执行成功
  48. //遍历结果集
  49. /***********Begin******/
  50. $rows=array();
  51. while($row=$result->fetch_assoc()){
  52. $rows[]=$row;
  53. }
  54. /*********end*******/
  55. //释放结果集资源
  56. $result->free();
  57. return $rows;
  58. } else {
  59. //执行失败
  60. return false;
  61. }
  62. }
  63. /**
  64. * 处理结果集中只有一条数据的方法
  65. * @param string $sql 待执行的SQL语句
  66. * @return array 返回结果集处理后的一维数组
  67. */
  68. public function fetchRow($sql) {
  69. //执行query()函数
  70. if ($result = $this->link->query($sql)) {
  71. //从结果集取得一次数据即可
  72. /***********Begin******/
  73. $row=$result->fetch_assoc();
  74. return $row;
  75. /*********end*******/
  76. } else {
  77. return false;
  78. }
  79. }
  80. /**
  81. * 对数据进行安全处理
  82. * @param string $data 待转义字符串
  83. * @return string 转义后的字符串
  84. */
  85. function safeHandle($data){
  86. //转义字符串中的HTML标签
  87. $data = htmlspecialchars($data);
  88. //转义字符串中的特殊字符
  89. $data = mysqli_real_escape_string($this->link,$data);
  90. return $data;
  91. }
  92. }
  93. //初始化数据库
  94. $db=new Init();
  95. //判断是否有表单提交
  96. if(!empty($_POST)){
  97. //声明变量$value,用来保存字段信息
  98. $fields = array('e_name','e_dept','date_of_birth','date_of_entry');
  99. //声明变量$value,用来保存值信息
  100. $value = array();
  101. //遍历$allow_field,获取输入员工数据的键和值
  102. foreach($fields as $k => $v){
  103. $data = isset($_POST[$v]) ? $_POST[$v] : '';
  104. if($data=='') die($v.'字段不能为空');
  105. $data =$db-> safeHandle($data);
  106. //把字段使用反引号包裹,赋值给$fields数组
  107. $fields[$k] = "`$v`";
  108. //把值使用单引号包裹,赋值给$values数组
  109. $values[] = "'$data'";
  110. }
  111. //将$fields数组以逗号连接,赋值给$fields,组成insert语句中的字段部分
  112. $fields = implode(',', $fields);
  113. //将$values数组以逗号连接,赋值给$values,组成insert语句中的值部分
  114. $values = implode(',', $values);
  115. //最后把$fields和$values拼接到insert语句中,注意要指定表名
  116. $sql = "insert into `emp_info` ($fields) values ($values)";
  117. //执行SQL
  118. if($res = $db->query($sql)){
  119. //成功时返回到 showList.php
  120. header('Location: .owList.php');
  121. //停止脚本
  122. die;
  123. }else{
  124. //执行失败
  125. die('员工添加失败!');
  126. }
  127. }
  128. $sql = 'select * from emp_dept';
  129. //调用fetchAll()函数,执行SQL并进行数据处理,把处理后的部门数据赋值给$emp_dept
  130. $emp_dept = $db->fetchAll($sql);
  131. //没有表单提交时,显示员工添加页面
  132. define('APP', 'educoder');
  133. require 'add_html.php';

第3关:PHP实现下拉菜单显示数据 下

任务描述

在添加员工信息时,一般员工所属部门是不允许用户手动输入的,而是通过动态查询数据库,获取到部门表数据,以下拉菜单的形式展示到表单中,以供选择。你的下一个任务是完成员工添加及修改时动态获取部门信息的功能。

编程要求

补全右侧代码,要求实现的功能: 1.(上一关代码)补全右侧代码,为实现以下拉菜单来展现部门数据做准备。 2.(本关代码)补全右侧代码,下拉菜单的value为部门ID,下拉菜单的文字显示为部门名称。 其中,部门信息表都存储在数组$emp_dept中,数组的下标即为表的属性名。 表的结构如下

  1. create table emp_dept (
  2. d_id int unsigned primary key auto_increment,
  3. d_name varchar(20) not null
  4. );

测评说明

平台将自动编译补全后的代码,根据程序的输出判断是否正确。

代码如下:

  1. <?php
  2. require "empUpdate.php";
  3. if(!defined('APP')) die('error!');
  4. ?>
  5. <!doctype html>
  6. <html>
  7. <head>
  8. <meta charset="utf-8">
  9. <title>员工信息编辑</title>
  10. <link rel="stylesheet" href="./js/jquery.datetimepicker.css"/ >
  11. <script src="./js/jquery.js"></script>
  12. <script src="./js/jquery.datetimepicker.js"></script>
  13. <script>
  14. $(function(){
  15. $('#date_of_birth').datetimepicker({lang:'ch'});
  16. $('#date_of_entry').datetimepicker({lang:'ch'});
  17. });
  18. </script>
  19. <style>
  20. body{background-color:#eee;margin:0;padding:0;}
  21. .box{width:400px;margin:15px auto;padding:20px;border:1px solid #ccc;background-color:#fff;}
  22. .box h1{font-size:20px;text-align:center;}
  23. .profile-table{margin:0 auto;}
  24. .profile-table th{font-weight:normal;text-align:right;}
  25. .profile-table input[type="text"]{width:180px;border:1px solid #ccc;height:22px;padding-left:4px;}
  26. .profile-table .button{background-color:#0099ff;border:1px solid #0099ff;color:#fff;width:80px;height:25px;margin:0 5px;cursor:pointer;}
  27. .profile-table .td-btn{text-align:center;padding-top:10px;}
  28. .profile-table th,.profile-table td{padding-bottom:10px;}
  29. .profile-table td{font-size:14px;}
  30. .profile-table .txttop{vertical-align:top;}
  31. .profile-table select{border:1px solid #ccc;min-width:80px;height:25px;}
  32. .profile-table .description{font-size:13px;width:250px;height:60px;border:1px solid #ccc;}
  33. </style>
  34. </head>
  35. <body>
  36. <div class="box">
  37. <h1>修改员工信息</h1>
  38. <form method="post">
  39. <table class="profile-table">
  40. <tr><th>姓名:</th><td><input type="text" name="e_name" value="<?php echo $emp_info['e_name']; ?>"/></td></tr>
  41. <tr><th>所属部门:</th>
  42. <td>
  43. <!—下拉菜单开始-->
  44. <!—在输出每个部门信息时,判断是否为该员工当前所属部门,如果是设置为默认项selected='selected'-->
  45. <!somecodes here-->
  46. <select name="d_id">
  47. <?php foreach ($emp_dept as $row){?>
  48. <option value="<?php echo $row['d_id'];?>"><?php echo $row['d_name'];?></option>
  49. <?php }?>
  50. </select>
  51. <!—下拉菜单结束-->
  52. </td></tr>
  53. <tr><th>出生年月:</th><td><input id="date_of_birth" name="date_of_birth" type="text" value="<?php echo $emp_info['date_of_birth']; ?>"></td></tr>
  54. <tr><th>入职日期:</th><td><input id="date_of_entry" name="date_of_entry" type="text" value="<?php echo $emp_info['date_of_entry']; ?>"></td></tr>
  55. <tr><td colspan="2" class="td-btn">
  56. <input type="submit" value="保存资料" class="button" />
  57. <input type="reset" value="重新填写" class="button" />
  58. </td></tr>
  59. </table>
  60. </form>
  61. </div>
  62. </body>
  63. </html><?php
  64. require "empUpdate.php";
  65. if(!defined('APP')) die('error!');
  66. ?>
  67. <!doctype html>
  68. <html>
  69. <head>
  70. <meta charset="utf-8">
  71. <title>员工信息编辑</title>
  72. <link rel="stylesheet" href="./js/jquery.datetimepicker.css"/ >
  73. <script src="./js/jquery.js"></script>
  74. <script src="./js/jquery.datetimepicker.js"></script>
  75. <script>
  76. $(function(){
  77. $('#date_of_birth').datetimepicker({lang:'ch'});
  78. $('#date_of_entry').datetimepicker({lang:'ch'});
  79. });
  80. </script>
  81. <style>
  82. body{background-color:#eee;margin:0;padding:0;}
  83. .box{width:400px;margin:15px auto;padding:20px;border:1px solid #ccc;background-color:#fff;}
  84. .box h1{font-size:20px;text-align:center;}
  85. .profile-table{margin:0 auto;}
  86. .profile-table th{font-weight:normal;text-align:right;}
  87. .profile-table input[type="text"]{width:180px;border:1px solid #ccc;height:22px;padding-left:4px;}
  88. .profile-table .button{background-color:#0099ff;border:1px solid #0099ff;color:#fff;width:80px;height:25px;margin:0 5px;cursor:pointer;}
  89. .profile-table .td-btn{text-align:center;padding-top:10px;}
  90. .profile-table th,.profile-table td{padding-bottom:10px;}
  91. .profile-table td{font-size:14px;}
  92. .profile-table .txttop{vertical-align:top;}
  93. .profile-table select{border:1px solid #ccc;min-width:80px;height:25px;}
  94. .profile-table .description{font-size:13px;width:250px;height:60px;border:1px solid #ccc;}
  95. </style>
  96. </head>
  97. <body>
  98. <div class="box">
  99. <h1>修改员工信息</h1>
  100. <form method="post">
  101. <table class="profile-table">
  102. <tr><th>姓名:</th><td><input type="text" name="e_name" value="<?php echo $emp_info['e_name']; ?>"/></td></tr>
  103. <tr><th>所属部门:</th>
  104. <td>
  105. <!—下拉菜单开始-->
  106. <!—在输出每个部门信息时,判断是否为该员工当前所属部门,如果是设置为默认项selected='selected'-->
  107. <!somecodes here-->
  108. <select name="d_id">
  109. <?php foreach ($emp_dept as $row){?>
  110. <option value="<?php echo $row['d_id'];?>"><?php echo $row['d_name'];?></option>
  111. <?php }?>
  112. </select>
  113. <!—下拉菜单结束-->
  114. </td></tr>
  115. <tr><th>出生年月:</th><td><input id="date_of_birth" name="date_of_birth" type="text" value="<?php echo $emp_info['date_of_birth']; ?>"></td></tr>
  116. <tr><th>入职日期:</th><td><input id="date_of_entry" name="date_of_entry" type="text" value="<?php echo $emp_info['date_of_entry']; ?>"></td></tr>
  117. <tr><td colspan="2" class="td-btn">
  118. <input type="submit" value="保存资料" class="button" />
  119. <input type="reset" value="重新填写" class="button" />
  120. </td></tr>
  121. </table>
  122. </form>
  123. </div>
  124. </body>
  125. </html>

第4关: PHP实现分页显示数据

任务描述

为了进一步加强使用时的用户体验,你打算在网站上应用分页链接的显示样式。这个分页样式由“首页”、“尾页”以及指定数量的中间页码组成。具体效果如下图所示。

为了完成这样一个相对灵活的分页样式,你需要学习以下知识。

编程要求

补全右侧代码,完成函数 makePageHtml($page, $max_page, $show_page_num = 5) 其中:

  • $page URL传递的page值
  • $max_page 最大页码值
  • $show_page_num 页面中显示多少页码
  • 返回值为该显示的分页链接,返回的分页链接格式为: 首页 1 2 3 4 5 > 尾页 以及 首页 < 6 尾页 其中,各个页码链接之间请用&nbsp;进行分隔。

测评说明

平台将自动编译补全后的代码,根据程序的输出判断是否正确。

代码如下:

  1. <?php
  2. /**
  3. * 分页链接生成函数
  4. * $page URL传递的page值
  5. * $max_page 最大页码值
  6. * $show_page_num 页面中显示多少页码
  7. */
  8. function makePageHtml($page, $max_page, $show_page_num = 5) {
  9. //将首页的链接存入字符串$page_html中
  10. /*******Begin********/
  11. $page_html='<a href="?page=1">首页</a>&nbsp;';
  12. /*******end*********/
  13. //根据当前页码$page计算出它的所在分组,以及需要显示的第一页$i和最后一页$max_i
  14. /*******Begin********/
  15. $page_grep=ceil($page/$show_page_num);
  16. $i=$show_page_num*($page_grep-1)+1;
  17. $max=$page_grep*$show_page_num;
  18. $max_i=($max<=$max_page)?$max:$max_page;
  19. /*******end*********/
  20. for ($i; $i <= $max_i; $i++) {
  21. //判断是否有上一个页面分组,若有则向$page_html中添加"<"的链接
  22. /*******Begin********/
  23. if(($i+$show_page_num-1) % $show_page_num==0 && $i>1){
  24. $page_html .='<a href="?page=' . ($i-1) . '"&lt;</a>&nbsp;';
  25. }
  26. /*******end*********/
  27. //判断是否为当前选中页,并添加入$page_html。这是因为当前选择页的链接与其他页的链接不同
  28. /*******Begin********/
  29. if($i==$page){
  30. $page_html .='<a class = "curl" href="?page=' . $i . '">' . $i . '</a>&nbsp;';
  31. }else{
  32. $page_html .='<a href="?page=' . $i . '">' . $i . '</a>&nbsp;';
  33. }
  34. /*******end*********/
  35. //判断是否有下一页,若有则向$page_html中添加">"的链接
  36. /*******Begin********/
  37. if($i % $show_page_num==0 && $i < $max_page){
  38. $page_html .='<a href="?page=' . ($i+1) . '">&gt;</a>&nbsp;';
  39. }
  40. /*******end*********/
  41. }
  42. //将尾页的链接存入字符串$page_html中
  43. /*******Begin********/
  44. $page_html .='<a href="?page=' . $max_page . '">尾页</a>&nbsp;';
  45. /*******end*********/
  46. //返回显示分页链接的字符串
  47. return $page_html;
  48. }
  49. require "showList.php";

如有问题,请留言联系!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/654648
推荐阅读
相关标签
  

闽ICP备14008679号