本节介绍如何自己DIY一个数据库管理工具,可以在页面输入sql 进行简单的增删改查操作。

首先,找到xampp的安装目录,打开htdocs:

新建一个php文件,名称为 mysqladmin.php

1.编写php服务器代码

1.1 写上php标签

首先,还是在这个页面,要写php代码,就需要有一个php标签:

我们的php代码要写在这个标签内。

1.2 数据库连接操作

xampp安装的mysql默认没有密码,不写就行。

1.3 获取form表单传过来的sql语句

1.4 用mysql_query函数执行传过来的sql语句

目前为止,代码已经足以对数据库进行增删改,接下来,我们来设计查询sql的实现。

1.5 用split函数分割sql语句,获取表名

1.6 通过表名去获取这张表所有的列,并且把列名用一个数组装起来

1.7 去查询sql中获取的结果集,展示到页面

if($tableName){

			$query = mysql_query("select COLUMN_NAME from information_schema.COLUMNS where  TABLE_NAME = '$tableName';") or die("<p style='color:red'>sql报错,错误信息为 ======> ".mysql_error()."</p>");

			//对结果集进行遍历 -- mysql_fetch_array

			$columns = array(); //储存这张表中所有的字段名称
$count = 0; //记录当前的下标 echo "<table>"; echo "<tr>"; while($row = mysql_fetch_array($query)){ $columns[$count] = $row["COLUMN_NAME"]; echo "<td>" . $row["COLUMN_NAME"] . "</td>"; $count = $count + 1; } echo "</tr>"; //echo sizeof($columns); $query_02 = mysql_query($sql) or die("<p style='color:red'>sql报错,错误信息为 ======> ".mysql_error()."</p>"); while($row = mysql_fetch_array($query_02)){ echo "<tr>";
for($i=0;$i<sizeof($columns);$i++){
echo "<td>" . $row[$columns[$i]] . "</td>";
}
echo "</tr>"; } echo "</table>"; } }

演示效果如下:

访问地址:http://localhost:8080/mysqladmin.php

完整的mysqladmin.php 代码:

<form action="mysqladmin.php" method="post" >

	<textarea cols="80" rows="10" id="sql" name="sql"></textarea>

	<br>

	<input type="submit" value="执行"  /> 

</form>

<style>

	th {background: #eaeaea}
td {border:1px solid #ccc;padding:2px 10px;}
tr:hover {background: skyblue}
</style> <?php //1、连接数据库
$conn = mysql_connect("localhost","root",""); //2、选择test数据库
$db = mysql_select_db("test",$conn); //3、设置编码集
mysql_query("set names utf8"); $sql = ""; if(isset($_POST["sql"]) && $_POST["sql"] != null){
$sql = $_POST["sql"];
echo "<p>您执行的sql为:$sql </p>"; echo "<script>document.getElementById('sql').value='".$sql."'</script>"; //开始真的执行sql $query_origin = mysql_query($sql) or die("<p style='color:red'>sql报错,错误信息为 ======> ".mysql_error()."</p>"); echo "<p style='color:green'>执行成功!</p>"; /*
如果是update语句,则返回一个数字
如果是select语句,则返回一个结果集,比如:Resource id #6
*/ //echo $query;
//echo strpos($query."",'Resource'); //select COLUMN_NAME from information_schema.`COLUMNS` where TABLE_NAME = 'tm_users'; //根据sql语句获取表名
$arr = split(" ",$sql);
$tableName = ""; for($i=0;$i<sizeof($arr);$i++){
if($arr[$i] == "from"){
$tableName = $arr[$i+1];
break;
}
} //echo $tableName; //如果表名存在,就去查询这个表中所有的字段
if($tableName){
$query = mysql_query("select COLUMN_NAME from information_schema.`COLUMNS` where TABLE_NAME = '$tableName'") or die("<p style='color:red'>sql报错,错误信息为 ======> ".mysql_error()."</p>"); $columns = array();
$count = 0; echo "<table cellpadding=0 cellspacing=0><tr>"; while($row=mysql_fetch_array($query)){ $columns[$count++] = $row['COLUMN_NAME']; } //遍历数组
for($i=0;$i<sizeof($columns);$i++){
echo "<th>$columns[$i]</th>";
} echo "</tr><tr>";
//然后去这张表里面查询
while($row=mysql_fetch_array($query_origin)){
//遍历这张表的列名,然后对应从行中取值
for($i=0;$i<sizeof($columns);$i++){
echo "<td>" . $row["$columns[$i]"] . "</td>";
}
//每遍历好一行,就换行
echo "</tr>";
} echo "</table>"; } } ?>

【php增删改查实例】第四节 -自己 DIY 一个数据库管理工具的更多相关文章

  1. 【php增删改查实例】第九节 - 部门管理模块(模糊查询)

    给datagrid添加一个工具栏. 效果: 模糊查询部门名称. 接下来,在工具栏区域画一个input框: <div id="toolbar" style="padd ...

  2. 【php增删改查实例】 第二节 - MYSQL环境配置

    安装好xampp后,会自带一个mysql,也就是说,正常情况下,你直接这样: 就可以启动mysql了. 如果你了,下面的步骤就别看了哈. if( 启动成功 ){ return; } 如果你的电脑上已经 ...

  3. 【php增删改查实例】第一节 - PHP开发环境配置

    最近需要使用PHP,于是把平时的积累整理一下,就有了这个教程. 首先是环境配置: 1.操作系统:windos7 2.后台:PHP 3.前台:Html + js + css 4.数据库:MYSQL 5. ...

  4. yii2.0增删改查实例讲解

    yii2.0增删改查实例讲解一.创建数据库文件. 创建表 CREATE TABLE `resource` ( `id` int(10) NOT NULL AUTO_INCREMENT, `textur ...

  5. JS组件系列——BootstrapTable+KnockoutJS实现增删改查解决方案(四):自定义T4模板快速生成页面

    前言:上篇介绍了下ko增删改查的封装,确实节省了大量的js代码.博主是一个喜欢偷懒的人,总觉得这些基础的增删改查效果能不能通过一个什么工具直接生成页面效果,啥代码都不用写了,那该多爽.于是研究了下T4 ...

  6. python链接oracle数据库以及数据库的增删改查实例

    初次使用python链接oracle,所以想记录下我遇到的问题,便于向我这样初次尝试的朋友能够快速的配置好环境进入开发环节. 1.首先,python链接oracle数据库需要配置好环境. 我的相关环境 ...

  7. java:JSP(JSPWeb.xml的配置,动态和静态导入JSP文件,重定项和请求转发,使用JSP实现数据库的增删改查实例)

    1.JSP的配置: <%@ page language="java" import="java.util.*" pageEncoding="UT ...

  8. 百度鹰眼Java接口调用增删改查实例

    因感觉百度鹰眼的使用场景比较符合实际业务,于是对百度鹰眼做了简单功能调试.刚开始使用springframework封装的RestTemplate,但是测试提示ak参数不存在.后又试了几种方法,均提示a ...

  9. Maven多模块项目+MVC框架+AJAX技术+layui分页对数据库增删改查实例

    昨天刚入门Maven多模块项目,所以简单写了一个小测试,就是对数据库单表的增删改查,例子比较综合,写得哪里不妥还望大神赐教,感谢! 首先看一下项目结构: 可以看到,一个项目MavenEmployee里 ...

随机推荐

  1. ES6 箭头函数下的this指向

    在javscript中,this 是在函数运行时自动生成的一个内部指针,它指向函数的调用者. 箭头函数有些不同,它的this是继承而来, 默认指向在定义它时所处的对象(宿主对象),而不是执行时的对象. ...

  2. 新知食APP架构分析--北京识物科技有限公司旗下产品

    俗话说不打无准备之仗,这次真是有点懵逼了,建议大家去面试的时候,尤其是去小型互联网公司的时候,如果你想比其他人有竞争力,那么你要研究一下当前他的公司正在开发产品,他们的业务类型是什么样的,比如他们公司 ...

  3. MAYA逼真手枪制作视频教程 中文字幕

    下载地址 更多中文字幕教程请关注微镜映画网,有各类CG教程提供

  4. SQL Server客户端工具到底使用的是哪个provider呢?

    SQL Server客户端工具到底使用的是哪个provider呢? 转载自:http://blogs.msdn.com/b/apgcdsd/archive/2013/01/10/sql-server- ...

  5. SQLSERVER文件组误脱机后如何联机

    场景:在学习文件组的恢复过程中,通过 ALTER DATABASE TEST MODIFY FILE(NAME = SUBF,OFFLINE) 把文件组给弄脱机了.这时却发现脱机之前忘记备份了. 这时 ...

  6. CSS| 實例---寬度自由調節button,圖片切換

    <html lang="en"> <head> <meta charset="utf-8"/> <title>I ...

  7. 转:.Net内存泄露原因及解决办法

    1.    什么是.Net内存泄露 (1).NET 应用程序中的内存 您大概已经知道,.NET 应用程序中要使用多种类型的内存,包括:堆栈.非托管堆和托管堆.这里我们需要简单回顾一下. 以运行库为目标 ...

  8. 搭建企业级NFS网络文件共享服务

    NFS服务简介 NFS是Network  File System(网络文件系统).主要功能是通过网络让不同的服务器之间可以共享文件或者目录.NFS客户端一般是应用服务器(比如web,负载均衡等),可以 ...

  9. MySQL一个延迟案例

    突然接到报警显示MySQL主从之间延迟过大,随后尽快到集群上面看看,进行排查. 首先我们查看延迟是由什么造成的,排查一遍过后发现不是网卡和从库机器的负载,那就要从其他地方来排除了 查看binlog日志 ...

  10. October 10th 2017 Week 41st Tuesday

    If you focus on what you left behind you will never see what lies ahead. 如果你只顾回头看,那么你永远也看不见前方有什么. Ye ...