头歌php mysql操作答案

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 头歌php mysql操作答案

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

<?php
/**
 * 初始化数据库连接
 */
require 'public_function.php';
//创建对象,连接数据库
/*****begin*********/
$link=new mysqli('127.0.0.1','root','123123');
/*****end*********/
//判断数据库连接是否成功,如果不成功则显示错误信息并终止脚本继续执行
if($link->connect_error){
    die('连接数据库失败!'.$link->connect_error);
}
//设置字符集,选择数据库
$link->query("drop database if exists 'educoder';");
$link->query("create database educoder;");
$link->query('set names utf8;');
$link->query('use educoder;');
//创建部门信息表
/*****begin*********/
$sql="create table emp_dept(
    d_id int unsigned primary key auto_increment,d_name varchar(20) not null) charset=utf8;";
$link->query($sql);
/*****end*********/
//向部门信息表中插入数据
/*****begin*********/
$sql="INSERT INTO emp_dept VALUES 
     (1, '开发部'), (2, '媒体部'), (3, '人事部'),(4, '后勤部'), 
     (5, '市场部'),  (6, '运维部'), (7, '销售部');";
$link->query($sql);
/*****end*********/
//修改用户表
/*****begin*********/
$sql="drop table if exists emp_info;";
$link->query($sql);
 $sql="create table emp_info (
    e_id int unsigned primary key auto_increment, 
    e_name varchar(20) not null, 
    d_id int unsigned not null, 
    date_of_birth timestamp not null, 
    date_of_entry timestamp not null
    )charset=utf8;";
$link->query($sql);
/*****end*********/
//向其中添加用户数据
/*****begin*********/
$sql="INSERT INTO emp_info VALUES
(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');";
$link->query($sql);
/*****end*********/
//左连接查询
//填充下面sql语句
$sql="select emp.e_id,emp.e_name,emp.date_of_birth,emp.date_of_entry,dept.d_name
      from emp_info as emp  
      left join emp_dept as dept
      on emp.d_id = dept.d_id;";
$result=$link->query($sql);
$db=new Init();
$emp_info =$db->fetchAll($sql);
//设置常量,用以判断视图页面是否由此页面加载
define('APP', 'educoder');
//加载视图页面,显示数据
require 'list_html.php';

 

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


<?php
/**
 * 初始化数据库连接
 */
Class Init
{
    private $link;
    private static $host="127.0.0.1";
    private static $root="root";
    private static $password="123123";
    function __construct()
    {
        $this->link=new mysqli(self::$host,self::$root,self::$password);
        //判断数据库连接是否成功,如果不成功则显示错误信息并终止脚本继续执行
        if($this->link->connect_error){
            die('连接数据库失败!');
        }
        //设置字符集,选择数据库
        $this->link->query('set names utf8;');
        $this->link->query('use educoder;');
    }
    /**
     * 执行SQL的方法
     * @param string $sql 待执行的SQL
     * @return mixed 失败返回false,成功,如果是查询语句返回结果集,如果非查询类返回true
     */
    public function query($sql) {
       /***********Begin******/
      if ($result =$this->link->query($sql)) {
            return $result;
        }else{
            echo 'SQL执行失败:<br>';
            echo '错误的SQL为:',$sql,'<br>';
            echo '错误的代码为:',$this->link->connect_errno,'<br>';
            echo '错误的信息为:',$this->link->connect_error,'<br>';
            return false;
        }
        /*********end*******/
    }
    /**
     * 处理结果集中有多条数据的方法
     * @param string $sql 待执行的SQL
     * @return array 返回遍历结果集后的二维数组
     */
    public function fetchAll($sql) {
        if ($result =$this->link->query($sql)) {
            //执行成功
            //遍历结果集
            /***********Begin******/
         $rows=array();
        while($row=$result->fetch_assoc()){
            $rows[]=$row;
        }
        /*********end*******/
            //释放结果集资源
            $result->free();
            return $rows;
        } else {
            //执行失败
            return false;
        }
    }
    /**
     * 处理结果集中只有一条数据的方法
     * @param string $sql 待执行的SQL语句
     * @return array 返回结果集处理后的一维数组
     */
    public function fetchRow($sql) {
        //执行query()函数
        if ($result = $this->link->query($sql)) {
            //从结果集取得一次数据即可
           /***********Begin******/
         $row=$result->fetch_assoc();
        return $row;
        /*********end*******/
        } else {
            return false;
        }
    }
    /**
     * 对数据进行安全处理
     * @param string $data 待转义字符串
     * @return string 转义后的字符串
     */
    function safeHandle($data){
        //转义字符串中的HTML标签
        $data = htmlspecialchars($data);
        //转义字符串中的特殊字符
        $data = mysqli_real_escape_string($this->link,$data);
        return $data;
    }
}
//初始化数据库
$db=new Init();
//判断是否有表单提交
if(!empty($_POST)){
    //声明变量$value,用来保存字段信息
    $fields = array('e_name','e_dept','date_of_birth','date_of_entry');
    //声明变量$value,用来保存值信息
    $value = array();
    //遍历$allow_field,获取输入员工数据的键和值
    foreach($fields as $k => $v){
        $data = isset($_POST[$v]) ? $_POST[$v] : '';
        if($data=='') die($v.'字段不能为空');
        $data =$db-> safeHandle($data);
        //把字段使用反引号包裹,赋值给$fields数组
        $fields[$k] = "`$v`";
        //把值使用单引号包裹,赋值给$values数组
        $values[] = "'$data'";
    }
    //将$fields数组以逗号连接,赋值给$fields,组成insert语句中的字段部分
    $fields = implode(',', $fields);
    //将$values数组以逗号连接,赋值给$values,组成insert语句中的值部分
    $values = implode(',', $values);
    //最后把$fields和$values拼接到insert语句中,注意要指定表名
    $sql = "insert into `emp_info` ($fields) values ($values)";
    //执行SQL
    if($res = $db->query($sql)){
        //成功时返回到 showList.php
        header('Location: ./showList.php');
        //停止脚本
        die;
    }else{
        //执行失败
        die('员工添加失败!');
    }
}
$sql = 'select * from emp_dept';
//调用fetchAll()函数,执行SQL并进行数据处理,把处理后的部门数据赋值给$emp_dept
$emp_dept = $db->fetchAll($sql);
//没有表单提交时,显示员工添加页面
define('APP', 'educoder');
require 'add_html.php';

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

<?php
require "empUpdate.php";
if(!defined('APP')) die('error!');
?>
<!doctype html>
<html>
<head>
    <meta charset="utf-8">
    <title>员工信息编辑</title>
    <link rel="stylesheet" href="./js/jquery.datetimepicker.css"/ >
    <script src="./js/jquery.js"></script>
    <script src="./js/jquery.datetimepicker.js"></script>
    <script>
        $(function(){
            $('#date_of_birth').datetimepicker({lang:'ch'});
            $('#date_of_entry').datetimepicker({lang:'ch'});
        });
    </script>
    <style>
        body{background-color:#eee;margin:0;padding:0;}
        .box{width:400px;margin:15px auto;padding:20px;border:1px solid #ccc;background-color:#fff;}
        .box h1{font-size:20px;text-align:center;}
        .profile-table{margin:0 auto;}
        .profile-table th{font-weight:normal;text-align:right;}
        .profile-table input[type="text"]{width:180px;border:1px solid #ccc;height:22px;padding-left:4px;}
        .profile-table .button{background-color:#0099ff;border:1px solid #0099ff;color:#fff;width:80px;height:25px;margin:0 5px;cursor:pointer;}
        .profile-table .td-btn{text-align:center;padding-top:10px;}
        .profile-table th,.profile-table td{padding-bottom:10px;}
        .profile-table td{font-size:14px;}
        .profile-table .txttop{vertical-align:top;}
        .profile-table select{border:1px solid #ccc;min-width:80px;height:25px;}
        .profile-table .description{font-size:13px;width:250px;height:60px;border:1px solid #ccc;}
    </style>
</head>
<body>
<div class="box">
    <h1>修改员工信息</h1>
    <form method="post">
        <table class="profile-table">
            <tr><th>姓名:</th><td><input type="text" name="e_name" value="<?php echo $emp_info['e_name']; ?>"/></td></tr>
            <tr><th>所属部门:</th>
                <td>
                    <!—下拉菜单开始-->
                    <!—在输出每个部门信息时,判断是否为该员工当前所属部门,如果是设置为默认项selected='selected'-->
                     <!somecodes here-->
<!somecodes here-->
                    <select name="d_id">
                    <?php foreach ($emp_dept as $row){?>
                    <option value="<?php echo $row['d_id'];?>"><?php echo $row['d_name'];?></option>
                    <?php }?>
                    </select>
                    <!—下拉菜单结束-->
                </td></tr>
            <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>
            <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>
            <tr><td colspan="2" class="td-btn">
                    <input type="submit" value="保存资料" class="button" />
                    <input type="reset" value="重新填写" class="button" />
                </td></tr>
        </table>
    </form>
</div>
</body>
</html>
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
安全 关系型数据库 MySQL
PHP与MySQL交互:从入门到实践
【9月更文挑战第20天】在数字时代的浪潮中,掌握PHP与MySQL的互动成为了开发动态网站和应用程序的关键。本文将通过简明的语言和实例,引导你理解PHP如何与MySQL数据库进行对话,开启你的编程之旅。我们将从连接数据库开始,逐步深入到执行查询、处理结果,以及应对常见的挑战。无论你是初学者还是希望提升技能的开发者,这篇文章都将为你提供实用的知识和技巧。让我们一起探索PHP与MySQL交互的世界,解锁数据的力量!
|
6天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
19 1
|
11天前
|
存储 关系型数据库 MySQL
PHP与MySQL动态网站开发深度解析####
本文作为技术性文章,深入探讨了PHP与MySQL结合在动态网站开发中的应用实践,从环境搭建到具体案例实现,旨在为开发者提供一套详尽的实战指南。不同于常规摘要仅概述内容,本文将以“手把手”的教学方式,引导读者逐步构建一个功能完备的动态网站,涵盖前端用户界面设计、后端逻辑处理及数据库高效管理等关键环节,确保读者能够全面掌握PHP与MySQL在动态网站开发中的精髓。 ####
|
12天前
|
关系型数据库 MySQL PHP
PHP与MySQL动态网站开发实战指南####
本文深入探讨了PHP与MySQL在动态网站开发中的应用实践,通过具体案例解析如何高效结合这两大技术构建数据驱动的Web应用。文章将涵盖环境搭建、基础语法回顾、数据库设计与操作、用户注册与登录系统实现等关键步骤,旨在为开发者提供一个从零到一的项目实战路径,展示PHP与MySQL协同工作的强大能力。 ####
|
1月前
|
SQL 关系型数据库 MySQL
PHP与MySQL协同工作的艺术:开发高效动态网站
在这个后端技术迅速迭代的时代,PHP和MySQL的组合仍然是创建动态网站和应用的主流选择之一。本文将带领读者深入理解PHP后端逻辑与MySQL数据库之间的协同工作方式,包括数据的检索、插入、更新和删除操作。文章将通过一系列实用的示例和最佳实践,揭示如何充分利用这两种技术的优势,构建高效、安全且易于维护的动态网站。
|
8天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
23 4
|
1月前
|
存储 关系型数据库 MySQL
Mysql(4)—数据库索引
数据库索引是用于提高数据检索效率的数据结构,类似于书籍中的索引。它允许用户快速找到数据,而无需扫描整个表。MySQL中的索引可以显著提升查询速度,使数据库操作更加高效。索引的发展经历了从无索引、简单索引到B-树、哈希索引、位图索引、全文索引等多个阶段。
61 3
Mysql(4)—数据库索引
|
15天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
80 1
|
17天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
59 2
|
20天前
|
存储 关系型数据库 MySQL
MySQL vs. PostgreSQL:选择适合你的开源数据库
在众多开源数据库中,MySQL和PostgreSQL无疑是最受欢迎的两个。它们都有着强大的功能、广泛的社区支持和丰富的生态系统。然而,它们在设计理念、性能特点、功能特性等方面存在着显著的差异。本文将从这三个方面对MySQL和PostgreSQL进行比较,以帮助您选择更适合您需求的开源数据库。
80 4