ThinkPHP6获取数据库内所有表的表名及表信息
发表于:2022-08-18 09:51:01浏览:3039次
thinkphp6 如何获取数据表所有的表名及表信息?下面就给大家介绍简单实用的方法,对ThinkPHP6数据库表管理,获取数据库内所有表的信息,包括表名、引擎、行格式、数据量、数据大小、索引长度、修改时间、创建时间、注释等信息。
1、Controller控制器代码:
<?php
declare (strict_types = 1);
namespace app\admin\controller;
use app\BaseController;
use think\facade\Db;
use think\facade\View;
class Database
{
public function datadb()
{
$this->showdb('cms_gougucms',2);//调用函数
return View::fetch('datadb/database');
}
/**
* 数据表信息查询方法
* table_name 数据表名
* mode 查询模式 1:查询指定表信息(需要table_name) 2:查询所有表信息
* @return 返回数据表信息Array数组
*/
public function showdb($table_name,$mode=1)
{
if($mode==1){
//查询指定表信息
$table_info = Db::query('SHOW TABLE STATUS LIKE ' . "'" . $table_name . "'");
}
if($mode==2){
//查询所有表信息
$table_info = Db::query('SHOW TABLE STATUS');
}
//查询所有表名
//$table_list = Db::query('SHOW TABLES');
View::assign('table_info',$table_info);//模板变量赋值
}
}
2、模板文件的HTML代码,通过volist标签循环输出:
<div class="layui-card-body layui-table-body layui-table-main">
<table class="layui-table layui-form">
<thead>
<th>
<input type="checkbox" lay-filter="checkall" name="" lay-skin="primary">
</th>
<th>ID</th>
<th>表名</th>
<th>数据量</th>
<th>数据大小</th>
<th>创建时间</th>
<th>注释</th>
<th>备份状态</th>
<th>操作</th>
</thead>
<tbody>
{volist name="table_info" id="v"}
<tr>
<th>
<input type="checkbox" lay-filter="checkall" name="" lay-skin="primary">
</th>
<td>{$i}</td>
<td>{$v.Name}</td>
<td>{$v.Rows}</td>
<td>{$v.Data_length}B</td>
<td>{$v.Create_time}</td>
<td>{$v.Comment}</td>
<td class="info">备份未开始</td>
<td>
<a href="javascript:;" class="layui-btn layui-btn-xs optimiz" tables="tplay_admin">优化表</a>
<a href="javascript:;" class="layui-btn layui-btn-xs repair" tables="tplay_admin">修复表</a>
</td>
</tr>
{/volist}
</tbody>
</table>
</div>
ThinkPHP6获取数据库中某个表的所有字段名称。
$table_info = Db::query("show COLUMNS FROM admin");
结果:
推荐文章
- 一个简单的thinkphp6的路由配置实例
- 烦人啊!微信总是弹出企业微信邀请信息,怎么关闭通知?
- PHP写入文件的方法,读取文件内容的五种方式
- ThinkPHP6判断HTTP的请求类型是GET,POST,PUT,DELETE或者HEAD
- PHP中,如果存在继承关系,其中子类和父类都定义了构造函数__construct(),怎么处理?
- 电商网站高并发秒杀系统如何实现正确的扣减库存?
- 前端报错:was loaded over HTTPS, but requested an insecure错误解决方案
- 微信小程序image属性mode的13种模式
- TinyMCE是一个轻量、简洁、功能强大的富文本编辑器
- phpword 使用TemplateProcessor方式实现在word模板中动态插入表格