tp5 r3 一个简单的SQL语句调试实例
tp5 r3 一个简单的SQL语句调试实例
先看效果
核心代码
- public function index()
- {
- if (IS_AJAX && session("uid")==1){
- $sql=input("post.sql");
- $sql=base64_decode($sql);
- if ($sql){
- if (preg_match('/INSERT INTO|DELETE|UPDATE\s/i', $sql, $info)){
- $result=\think\Db::execute($sql);
- }
- else{
- $result=\think\Db::query($sql);
- }
- return dump($result);//json_encode($result)
- }else{
- return "错误的sql语句";
- }
- }
- //读取所有的表
- $tables=\think\Db::query('SHOW TABLES');
- $this->assign('tables',$tables);
- $database=\think\Config::get("database");
- $this->assign('tkey',"tables_in_".$database["database"]);
- return $this->fetch();
- }
前台
- {include file="Public:header" /}
- <div id="page-content" style="min-height: 395px;">
- <div class="row">
- <div class="col-md-6">
- <div class="block full">
- <div class="block-title"><h2>数据库命令</h2></div>
- <form id="form-sql" onsubmit="return!1" class="form-horizontal form-bordered" method="post" action="{:url('db/index?type=save')}">
- <div class="form-group">
- <div class="col-md-9 col-md-offset-3">
- <div class="col-xs-6">
- <select size="1" class="form-control" id="tables">
- {volist name="tables" id="vo"}
- <option value="{$vo[$tkey]}">{$vo[$tkey]}</option>
- {/volist}
- </select>
- </div>
- <div class="btn-group">
- <a class="btn btn-default dropdown-toggle" data-toggle="dropdown" href="javascript:void(0)" aria-expanded="false">快捷SQL语句<span class="caret"></span></a>
- <ul class="dropdown-menu text-left">
- <li class="dropdown-header"><i class="fa fa-user pull-right"></i><strong>select语句</strong></li>
- <li><a href="javascript:insert('SELECT * FROM `[table]` WHERE 1')">select</a></li>
- <li><a href="javascript:insert('INSERT INTO `[table]` VALUES ([value-1],[value-2],[value-3],[value-4],[value-5])')">insert</a></li>
- <li><a href="javascript:insert('UPDATE `[table]` SET `[]`=[value-2] WHERE 1')">update</a></li>
- <li><a href="javascript:insert('DELETE FROM `[table]` WHERE 1')">delete</a></li>
- <li class="divider"></li>
- </ul>
- </div>
- </div>
- </div>
- <div class="form-group">
- <label for="example-textarea-input" class="col-md-3 control-label">SQL命令语句</label>
- <div class="col-md-9">
- <textarea placeholder="SQL命令语句" class="form-control" rows="7" name="sql" id="sql"></textarea>
- </div>
- </div>
- <div class="form-group form-actions">
- <div class="col-md-9 col-md-offset-3">
- <button class="btn btn-effect-ripple btn-primary" id="form" type="button" style="overflow:hidden;position:relative">提交</button>
- <button class="btn btn-effect-ripple btn-danger" type="reset" style="overflow:hidden;position:relative">重置</button>
- </div>
- </div>
- </form>
- </div>
- </div>
- <div class="col-md-6">
- <div class="block full">
- <div class="block-title"><h2>输出结果</h2></div>
- <p id="result" style="#cccccc;"></p>
- </div>
- </div>
- </div>
- </div>
- {include file="Public:footer" /}
- <script src="__PUBLIC__/static/js/base64/base64.js"></script>
- <script>
- function insert($sql){
- if ($sql){
- var table=$("#tables").val();
- $("#sql").text($sql.replace("[table]", table));
- }
- }
- $("#form").click(function(){
- var sql=$("#sql").val();
- var url =$("#form-sql").attr("action");
- if (!sql){jError("SQL不能为空!!", {VerticalPosition: 'center',HorizontalPosition: 'center'});return;}
- sql=base64_encode(sql);
- $.ajax({
- url:url,
- data:{sql:sql},
- type:'post',
- cache:true,
- dataType:'html',
- success:function(data) {
- $("#result").html(data);
- },
- error : function() {
- $("#result").html('错误的SQL语句!<br/>'+$("#sql").val());
- jError("错误的SQL语句!", {VerticalPosition: 'center',HorizontalPosition: 'center'});
- }
- });
- })
- </script>
tp5 r3 一个简单的SQL语句调试实例的更多相关文章
- SQL点滴10—使用with语句来写一个稍微复杂sql语句,附加和子查询的性能对比
原文:SQL点滴10-使用with语句来写一个稍微复杂sql语句,附加和子查询的性能对比 今天偶尔看到sql中也有with关键字,好歹也写了几年的sql语句,居然第一次接触,无知啊.看了一位博主的文章 ...
- [20190328]简单探究sql语句相关mutexes.txt
[20190328]简单探究sql语句相关mutexes.txt --//摘要:http://www.askmaclean.com/archives/understanding-oracle-mute ...
- 四种简单的sql语句(增删改查语句)
四种简单的sql语句(增删改查语句) 一.插入语句 insert into [table] ([column],[column],[column]) values(?,?,?) 二.删除语句 dele ...
- 使用with语句来写一个稍微复杂sql语句,附加和子查询的性能对比
今天偶尔看到sql中也有with关键字,好歹也写了几年的sql语句,居然第一次接触,无知啊.看了一位博主的文章,自己添加了一些内容,做了简单的总结,这个语句还是第一次见到,学习了.我从简单到复杂地写, ...
- UI:简单的SQL语句
一.SQL语句如果要在程序运行过程中操作数据库中的数据,那得先学会使用SQL语句1.什么是SQLSQL(structured query language):结构化查询语言SQL是一种对关系型数据库中 ...
- 数据库学习之简单的SQL语句
1.数据库的结构 1.1数据库 不同数据库叫做Catalog(在有的 DBMS 中也称为 Database,即数据库) .採用多 Catalog 以后能够给我们带 来例如以下优点: 便于对各个 Cat ...
- 一些简单的SQL语句
简单的SQL入门 一,简介 1, 一个数据库包含一个或多个表,表包含带有数据的记录(行) 2, SQL对大小写不敏感,语句的分号看具体情况 二,语法 1, 数据操作语言:DML a) ...
- 简单的SQL语句
说明:SQL语句大小写都可以,执行一句时,后面可不加分号,如果同时执行两句,就必须加分号,不然会报错. --+空格 是SQL的注释 表格名为users,里面有name和age属性 一.增 inser ...
- JDBC之java数据库的连接与简单的sql语句执行
import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sq ...
随机推荐
- CODE FESTIVAL 2016 qualA Grid and Integers
划年代久远的水 题意 有一个R*C的棋盘,要求在每个格子上填一个非负数,使得对任意一个2*2的正方形区域,左上角和右下角的数字之和等于左下角和右上角的数字之和.有一些格子已经被填上了数字,问现在能否满 ...
- 洛谷 P1576 最小花费
题目戳 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元. ...
- [您有新的未分配科技点]数位DP:从板子到基础(例题 bzoj1026 windy数 bzoj3131 淘金)
只会统计数位个数或者某种”符合简单规律”的数并不够……我们需要更多的套路和应用 数位dp中常用的思想是“分类讨论”思想.下面我们就看一道典型的分类讨论例题 1026: [SCOI2009]windy数 ...
- Spring Boot系列教程六:日志输出配置log4j2
一.前言 spring boot支持的日志框架有,logback,Log4j2,Log4j和Java Util Logging,默认使用的是logback日志框架,笔者一直在使用log4j2,并且 ...
- 【BZOJ5248】【九省联考2018】一双木棋(搜索,哈希)
[BZOJ5248][九省联考2018]一双木棋(搜索,哈希) 题面 BZOJ Description 菲菲和牛牛在一块n行m列的棋盘上下棋,菲菲执黑棋先手,牛牛执白棋后手.棋局开始时,棋盘上没有任何 ...
- xpose修改手机imei码,注入广告
何为hook Hook英文翻译过来就是“钩子”的意思,那我们在什么时候使用这个“钩子”呢? 我们知道,在Android操作系统中系统维护着自己的一套事件分发机制.应用程序,包括应用触发事件和后台逻 ...
- vs2003一查找就卡死了
Visual Studio 2003一查找就卡死了.解决办法如下: win7 32位下 解决方法:找到VS2003的安装目录,修改"...\Microsoft Visual Studio . ...
- angular 有关侦测组件变化的 ChangeDetectorRef 对象
我们知道,如果我们绑定了组件数据到视图,例如使用 <p>{{content}}</p>,如果我们在组件中改变了content的值,那么视图也会更新为对应的值. angular ...
- pdf 下载整理
pdf下载整理: using System; using System.Collections.Generic; using System.Linq; using System.Web; using ...
- mybatis基础犯错总结
1.关于mybatis的文件一般都是其mapper文件出错: 首先关于输入参数parameterType出错: (1)基本数据类型:如果输入参数只有一个,其数据类型可以是基本数据类型,也可以是自己定的 ...