- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想用 PHP 和 MySQL 做一个缺勤系统。每个缺勤都有一个休假类型。我想在生成的 HTML 表格中显示这种类型(例如生病)。左侧第一个字段显示用户名,其他为 31 个字段(如月份)。
我可以在表格中输入类型,但是我不知道如何只在正确的表格中显示它们。例如,“Max”的 PK 0 和缺席类型为“Emergency”和“ASDF”,PK 2 和“Compensation”,但类型在两个表中。
Array (
[0] =>
Array ( [start] => 0 [end] => 27 [type_FK] => Compensation [employee_FK] => 0 )
[1] =>
Array ( [start] => 1 [end] => 3 [type_FK] => Emergency [employee_FK] => 2 )
)
如何在该表中只显示正确用户的休假类型?
<html>
<head>
<meta charset="utf-8">
<link rel="stylesheet" type="text/css" href="css/style.css">
<title>Absence System</title>
</head>
<body>
<div id="container">
<?php
$con = mysql_connect("localhost", "root", "");
if (!$con) {
die('Could not connect: ' . mysql_error());
}
mysql_select_db("absence_system", $con);
$result = mysql_query("select count(1) FROM employee");
$row = mysql_fetch_array($result);
$count_user = $row[0];
$result2 = mysql_query("select start, end, type_FK, employee_FK FROM absences");
while ($row2 = mysql_fetch_assoc($result2)) {
$array_absences[] = $row2;
}
$count_absences = count($array_absences);
$result = mysql_query("select name FROM employee");
while ($row = mysql_fetch_assoc($result)) {
$array_user[] = $row;
}
$result = mysql_query("select surename FROM employee");
while ($row2 = mysql_fetch_assoc($result)) {
$new_array2[] = $row2;
}
for ($i = 0; $i < $count_absences; $i++) {
$array_absences[$i]['start'] = substr($array_absences[$i]['start'], -2);
$array_absences[$i]['end'] = substr($array_absences[$i]['end'], -2);
$array_absences[$i]['start'] = ereg_replace("^0", "", $array_absences[$i]['start']);
$array_absences[$i]['end'] = ereg_replace("^0", "", $array_absences[$i]['end']);
$array_absences[$i]['start'] = $array_absences[$i]['start'] - 1;
echo $array_absences[$i]['start'], "<br>";
}
print_r($array_absences);
echo "<table border='1'><br />";
echo "<tr>";
for ($i = 0; $i < 32; $i++) {
if ($i == 0) {
echo "<td>", "Name", "</td>";
} else {
echo "<td>", $i, "</td>";
}
}
echo "</tr>";
echo "</table>";
for ($row = 0; $row < $count_user; $row++) {
echo "<table border='1'><br />";
echo "<tr>";
//Tabelle mit 31 Tagen generieren
for ($col = 0; $col < 32; $col++) {
$true = 0;
if ($col == 0) {
//Name in die ersten Felder schreiben
echo "<td>", $array_user[$col]['name'], " ", $new_array2[$col]['surename'], "</td>";
}
for ($i = 0; $i < $count_absences; $i++) {
if ($col == $array_absences[$i]['start']) {
echo "<td>", $array_absences[$i]['type_FK'], "</td>";
$true = 1;
}
}
//Normale Felder
if ($true == 0) {
echo "<td>", $col, "</td>";
}
}
echo "</tr>";
}
echo "</table>";
?>
</div>
</body>
</html>
-- phpMyAdmin SQL Dump
-- version 4.2.11
-- http://www.phpmyadmin.net
--
-- Host: 127.0.0.1
-- Erstellungszeit: 13. Feb 2015 um 16:07
-- Server Version: 5.6.21
-- PHP-Version: 5.5.19
SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO";
SET time_zone = "+00:00";
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
--
-- Datenbank: `absence_system`
--
-- --------------------------------------------------------
--
-- Tabellenstruktur für Tabelle `absences`
--
CREATE TABLE IF NOT EXISTS `absences` (
`absences_ID` int(11) NOT NULL,
`employee_FK` int(11) NOT NULL,
`start` date NOT NULL,
`end` date NOT NULL,
`approved` tinyint(1) NOT NULL,
`comment` varchar(45) NOT NULL,
`type_FK` varchar(50) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
-- --------------------------------------------------------
--
-- Tabellenstruktur für Tabelle `employee`
--
CREATE TABLE IF NOT EXISTS `employee` (
`employee_ID` int(11) NOT NULL,
`name` varchar(45) NOT NULL,
`surename` varchar(45) NOT NULL,
`on_offshore_FK` int(11) NOT NULL,
`location_FK` int(11) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
-- --------------------------------------------------------
--
-- Tabellenstruktur für Tabelle `location`
--
CREATE TABLE IF NOT EXISTS `location` (
`location_ID` int(7) NOT NULL,
`country` varchar(45) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
-- --------------------------------------------------------
--
-- Tabellenstruktur für Tabelle `on_offshore`
--
CREATE TABLE IF NOT EXISTS `on_offshore` (
`on_offshore_ID` int(11) NOT NULL,
`on_off` varchar(45) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
-- --------------------------------------------------------
--
-- Tabellenstruktur für Tabelle `type`
--
CREATE TABLE IF NOT EXISTS `type` (
`type` varchar(50) NOT NULL DEFAULT ''
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
--
-- Indizes der exportierten Tabellen
--
--
-- Indizes für die Tabelle `absences`
--
ALTER TABLE `absences`
ADD PRIMARY KEY (`absences_ID`), ADD KEY `employee_FK` (`employee_FK`), ADD KEY `type_FK` (`type_FK`);
--
-- Indizes für die Tabelle `employee`
--
ALTER TABLE `employee`
ADD PRIMARY KEY (`employee_ID`), ADD KEY `on_offshore_FK` (`on_offshore_FK`), ADD KEY `location_FK` (`location_FK`);
--
-- Indizes für die Tabelle `location`
--
ALTER TABLE `location`
ADD PRIMARY KEY (`location_ID`);
--
-- Indizes für die Tabelle `on_offshore`
--
ALTER TABLE `on_offshore`
ADD PRIMARY KEY (`on_offshore_ID`);
--
-- Indizes für die Tabelle `type`
--
ALTER TABLE `type`
ADD PRIMARY KEY (`type`);
--
-- Constraints der exportierten Tabellen
--
--
-- Constraints der Tabelle `absences`
--
ALTER TABLE `absences`
ADD CONSTRAINT `absences_ibfk_2` FOREIGN KEY (`employee_FK`) REFERENCES `employee` (`employee_ID`),
ADD CONSTRAINT `absences_ibfk_3` FOREIGN KEY (`type_FK`) REFERENCES `type` (`type`);
--
-- Constraints der Tabelle `employee`
--
ALTER TABLE `employee`
ADD CONSTRAINT `employee_ibfk_1` FOREIGN KEY (`on_offshore_FK`) REFERENCES `on_offshore` (`on_offshore_ID`),
ADD CONSTRAINT `employee_ibfk_2` FOREIGN KEY (`location_FK`) REFERENCES `location` (`location_ID`);
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
最佳答案
按照这些思路尝试一些事情:
获取一个月的缺勤列表:Select * from abnissions_table
。
获取员工列表:从 abnances_table 中选择 *
。
创建一个空的 $employees
数组。循环遍历缺席结果,并针对每次缺席运行如下内容:
for($i=0;$i<count($absences_array);$i++){
if(!$employees[$absences_array[$i]['employee_FK']]['dates']){
$employees[$absences_array[$i]['employee_FK']]['dates'] = array();
}
$employees[$absences_array[$i]['employee_FK']]['dates'][$absences_array[$i]['employee_FK']['start']];
for( $j=$absences_array[$j]['employee_FK']['start'];$j<$absences_array[$j]['employee_FK']['end']; $j++){
$employees[$absences_array[$i]['employee_FK']]['dates'][$j];
}
}
现在你有一个字典的字典 - 这意味着像 $employees[$employee_id]['dates'][$date]
这样的东西会给你缺席类型或 null。
关于php - 在 PHP 生成的表中显示 MySQL 用户数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28502613/
我在 JavaScript 文件中运行 PHP,例如...... var = '';). 我需要使用 JavaScript 来扫描字符串中的 PHP 定界符(打开和关闭 PHP 的 )。 我已经知道使
我希望能够做这样的事情: php --determine-oldest-supported-php-version test.php 并得到这个输出: 7.2 也就是说,php 二进制检查 test.
我正在开发一个目前不使用任何框架的大型 php 站点。我的大问题是,随着时间的推移慢慢尝试将框架融入应用程序是否可取,例如在创建的新部件和更新的旧部件中? 比如所有的页面都是直接通过url服务的,有几
下面是我的源代码,我想在同一页面顶部的另一个 php 脚本中使用位于底部 php 脚本的变量 $r1。我需要一个简单的解决方案来解决这个问题。我想在代码中存在的更新查询中使用该变量。 $name)
我正在制作一个网站,根据不同的情况进行大量 PHP 重定向。就像这样...... header("Location: somesite.com/redirectedpage.php"); 为了安全起见
我有一个旧网站,我的 php 标签从 因为短标签已经显示出安全问题,并且在未来的版本中将不被支持。 关于php - 如何避免在 php 文件中写入
我有一个用 PHP 编写的配置文件,如下所示, 所以我想用PHP开发一个接口(interface),它可以编辑文件值,如$WEBPATH , $ACCOUNTPATH和 const值(value)观
我试图制作一个登录页面来学习基本的PHP,首先我希望我的独立PHP文件存储HTML文件的输入(带有表单),但是当我按下按钮时(触发POST到PHP脚本) )我一直收到令人不愉快的错误。 我已经搜索了S
我正在寻找一种让 PHP 以一种形式打印任意数组的方法,我可以将该数组作为赋值包含在我的(测试)代码中。 print_r 产生例如: Array ( [0] => qsr-part:1285 [1]
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: What is the max key size for an array in PHP? 正如标题所说,我想知道
我正在寻找一种让 PHP 以一种形式打印任意数组的方法,我可以将该数组作为赋值包含在我的(测试)代码中。 print_r 产生例如: Array ( [0] => qsr-part:1285 [1]
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 9 年前。 Improve this ques
我在 MySQL 数据库中有一个表,其中存储餐厅在每个工作日和时段提供的菜单。 表结构如下: i_type i_name i_cost i_day i_start i_
我有两页。 test1.php 和 test2.php。 我想做的就是在 test1.php 上点击提交,并将 test2.php 显示在 div 中。这实际上工作正常,但我需要向 test2.php
我得到了这个代码。我想通过textarea更新mysql。我在textarea中回显我的MySQL,但我不知道如何更新它,我应该把所有东西都放进去吗,因为_GET模式没有给我任何东西,我也尝试_GET
首先,我是 php 的新手,所以我仍在努力学习。我在 Wordpress 上创建了一个表单,我想将值插入一个表(data_test 表,我已经管理了),然后从 data_test 表中获取所有列(id
我有以下函数可以清理用户或网址的输入: function SanitizeString($var) { $var=stripslashes($var); $va
我有一个 html 页面,它使用 php 文件查询数据库,然后让用户登录,否则拒绝访问。我遇到的问题是它只是重定向到 php 文件的 url,并且从不对发生的事情提供反馈。这是我第一次使用 html、
我有一个页面充满了指向 pdf 的链接,我想跟踪哪些链接被单击。我以为我可以做如下的事情,但遇到了问题: query($sql); if($result){
我正在使用 从外部文本文件加载 HTML/PHP 代码 $f = fopen($filename, "r"); while ($line = fgets($f, 4096)) { print $l
我是一名优秀的程序员,十分优秀!