当前位置:首页>python>Python从入门到精通day43

Python从入门到精通day43

  • 2026-03-07 03:12:00
Python从入门到精通day43

Hive简介:基于Hadoop的大数据仓库工具

上一节我们详细讲解了Python接入MySQL的全流程实操,解决了结构化数据的持久化与操作问题。本节课,我们将聚焦大数据处理场景——介绍Hive这款主流的数据仓库工具。在海量数据(TB/PB级)处理中,Hive凭借对SQL的完美支持,让非Java/Scala开发者也能轻松实现大数据统计,是大数据生态中不可或缺的核心组件。

温馨提示:本文所有实操均基于Hadoop生态环境,案例延续电商场景的eshop数据库及相关表,建议大家先确保Hadoop集群正常运行、Hive服务启动,动手跟着敲命令、写代码,更易掌握核心逻辑。

一、Hive是什么?核心定位与价值

Hive是Facebook开源、目前由Apache软件基金会维护的一款基于Hadoop的数据仓库工具,也是应用最广泛的大数据处理解决方案之一。它的核心价值在于“降低大数据处理门槛”,能将SQL查询转变为MapReduce(Google提出的一个软件架构,用于大规模数据集的并行运算)任务,对SQL提供了完美的支持,能够非常方便的实现大数据统计。

说明:可以通过https://www.edureka.co/blog/hadoop-ecosystem来了解 Hadoop 生态圈,更好地理解Hive在其中的定位。

如果要简单介绍Hive,以下两点是其核心,记牢就能快速掌握Hive的核心逻辑:

  1. 1. 把HDFS(Hadoop分布式文件系统)中结构化的数据映射成表,无需关注底层文件存储细节,操作方式类似传统数据库;
  2. 2. 通过把HQL(Hive查询语言,类SQL)进行解析和转换,最终生成一系列基于Hadoop的MapReduce任务或Spark任务,通过执行这些任务完成对数据的处理。也就是说,即便不学习Java、Scala这样的编程语言,一样可以实现对海量数据的处理。

Hive的核心应用场景

Hive主要用于大数据离线批量分析,适合以下场景:

  • • 日志分析:处理网站、APP的海量访问日志,统计访问量、用户行为等;
  • • 报表生成:定期生成业务报表(如电商交易报表、用户画像报表);
  • • 数据仓库建设:对海量结构化、半结构化数据进行清洗、转换、存储,为数据分析提供支撑;
  • • 海量数据统计:如用户行为分析、商品销量统计、流量分析等,处理TB/PB级数据效率远超传统数据库。

二、Hive与传统关系型数据库(RDBMS)的核心对比

很多新手会将Hive与MySQL、Oracle等传统关系型数据库混淆,但二者的设计目标、执行方式、数据规模适配差异极大,具体对比如下表所示(清晰区分,避免踩坑):

对比维度
Hive
传统关系型数据库(RDBMS)
查询语言
HQL(类SQL,兼容大部分SQL语法)
SQL(标准结构化查询语言)
存储数据
HDFS(Hadoop分布式文件系统)
本地文件系统/专用存储设备
执行方式
分布式计算(MapReduce / Spark)
单机/集群Executor本地执行
执行延迟
高(适合离线批量处理,耗时分钟/小时级)
低(适合实时交互查询,耗时毫秒/秒级)
数据规模
超大(TB/PB级,适配海量数据)
中小规模(GB级以内,效率最优)

三、前置准备:Hive使用的5个核心步骤

使用Hive前,需先完成基础环境准备和数据预处理,步骤如下(假设已搭建好大数据平台):

  1. 1. 搭建如下图所示的大数据平台(核心包含Hadoop、Hive组件,新手可参考Hadoop生态圈文档完成搭建);
  1. 2. 通过Client节点(跳板机)访问大数据平台,确保能正常连接Hadoop集群和Hive服务;
  1. 3. 在Hadoop的文件系统(HDFS)中创建数据存储目录,用于存放后续要加载到Hive的数据:
hdfs dfs -mkdir /user/root
  1. 4. 将本地准备好的数据文件(如用户信息、交易记录)拷贝到Hadoop文件系统的指定目录:
hdfs dfs -put /home/ubuntu/data/* /user/root
  1. 5. 进入Hive命令行,后续所有建库、建表、查询操作均在此环境中执行:
hive

✅ 小提示:如果进入Hive命令行失败,检查Hive服务是否启动、Hadoop集群是否正常运行,以及环境变量配置是否正确。

四、核心操作:Hive建库建表与数据加载

Hive的使用流程与传统数据库类似(建库→建表→加载数据→查询),但适配大数据场景,支持复合数据类型、分区表等特性,以下是完整实操案例(基于电商场景eshop数据库):

1. 数据库操作(创建、删除、切换)

Hive数据库本质是HDFS中的一个目录,用于隔离不同业务场景的数据,核心命令如下:

-- 1. 创建数据库(eshop:电商场景示例,若不存在则创建)create database eshop;-- 2. 删除数据库(cascade:级联删除,删除数据库的同时删除库中所有表,避免报错)drop database eshop cascade;-- 3. 切换到目标数据库(后续操作均针对该数据库)use eshop;

2. Hive数据类型(基础+复合,重点掌握)

Hive支持丰富的数据类型,除了常见的基础类型,还提供适配复杂数据场景的复合类型,无需拆分表字段,适配大数据中多样的数据格式,具体如下:

(1)基本数据类型

数据类型
占用空间
支持版本
说明
tinyint
1-Byte
-
微整型(取值范围:-128~127)
smallint
2-Byte
-
小整数(取值范围:-32768~32767)
int
4-Byte
-
整数(取值范围:-2147483648~2147483647)
bigint
8-Byte
-
大整数(适合存储时间戳、海量计数)
boolean
-
-
布尔值(true/false,用于判断场景)
float
4-Byte
-
单精度浮点数(精度较低,不推荐用于金额)
double
8-Byte
-
双精度浮点数(精度高,推荐用于金额、分数等)
string
-
-
字符串(无长度限制,适配文本、JSON等格式)
binary
-
0.8版本及以上
二进制数据(用于存储图片、文件等)
timestamp
-
0.8版本及以上
时间戳(存储日期+时间,格式灵活)
decimal
-
0.11版本及以上
高精度小数(适合存储金额,避免精度丢失)
char
-
0.13版本及以上
固定长度字符串(长度固定,节省空间)
varchar
-
0.12版本及以上
可变长度字符串(长度可变,适配不确定长度的文本)
date
-
0.12版本及以上
日期(格式:yyyy-MM-dd,仅存储日期,不包含时间)

(2)复合数据类型(大数据场景高频使用)

适合存储嵌套、复杂结构的数据(如用户扩展信息、键值对标签),无需拆分表,提升数据处理效率:

数据类型
描述
例子
struct
和C语言中的结构体类似,支持嵌套字段
struct<first_name:string, last_name:string>(存储用户姓名,包含名和姓)
map
由键值对构成的元素的集合,支持按key取值
map<string,int>(存储用户标签:如{"vip":"1","level":"5"})
array
具有相同类型的变量的容器,支持按索引取值
array(存储用户爱好:如["运动","阅读","美食"])

3. 创建内部表(基础表类型,新手必学)

内部表(Managed Table):Hive会管理表的数据存储,删除表时会同步删除HDFS中对应的数据源文件,适合临时数据处理、中间结果存储,实操如下:

create table if notexists dim_user_info (    user_id string,          -- 用户ID(字符串类型,唯一标识用户)    user_name string,        -- 用户名    sex string,              -- 性别(如male/female)    age int,                 -- 年龄    city string,             -- 所在城市    firstactivetime string,  -- 首次激活时间(字符串格式,如2018-01-01)    level int,               -- 用户等级    extra1 string,           -- 扩展字段1(存储JSON格式字符串,如用户设备信息)    extra2 map<string,string>-- 扩展字段2(map类型,存储键值对,如{"phonebrand":"huawei","vip":"yes"}))row format delimited fields terminated by'\t'-- 字段分隔符:制表符(根据实际数据调整)collection items terminated by','-- 复合类型(array/struct)元素分隔符map keys terminated by':'-- map类型键值对分隔符lines terminated by'\n'-- 行分隔符:换行符stored as textfile;                                    -- 存储格式:文本文件(默认格式,适配大部分场景)

✅ 关键说明:建表时必须指定“分隔符”,否则Hive无法正确解析数据;if not exists表示“若表不存在则创建”,避免重复建表报错。

4. 加载数据到内部表

Hive本身不存储数据,数据实际存储在HDFS中,“加载数据”本质是将HDFS或本地的文件,关联到Hive表中,支持两种加载方式:

-- 方式1:从本地文件加载(local:表示本地路径,加载后本地文件仍存在)load data local inpath '/home/ubuntu/data/user_info/user_info.txt' overwrite intotable dim_user_info;-- 方式2:从HDFS文件加载(无local:表示HDFS路径,加载后HDFS原文件会被移动到表对应的目录)load data inpath '/user/root/user_info.txt' overwrite intotable dim_user_info;

⚠️ 注意:overwrite表示“覆盖表中已有数据”,若想追加数据,去掉overwrite即可(改为into table dim_user_info)。

5. 创建分区表(大数据核心特性,必掌握)

分区表:按指定字段(如日期、地区)分区存储数据,查询时可只扫描目标分区,避免全量扫描,大幅提升查询效率,适合按时间增量更新的数据(如电商交易记录、日志数据):

create table if notexists fact_user_trade (    user_name string,        -- 用户名    piece int,               -- 购买数量    price double,            -- 商品单价    pay_amount double,       -- 支付金额    goods_category string,   -- 商品品类(如food、clothes)    pay_time bigint-- 支付时间戳(后续可转换为日期格式))  partitioned by (dt string)  -- 按日期分区(dt格式:yyyy-MM-dd,如2019-03-24)row format delimited fields terminated by'\t'-- 字段分隔符:制表符

6. 分区数据加载与修复

(1)手动上传分区数据到HDFS

分区表的数据需按“分区目录”存储,手动上传数据到对应目录:

hdfs dfs -put /home/ubuntu/data/user_trade/* /user/hive/warehouse/eshop.db/fact_user_trade

(2)设置动态分区(可选,高效加载多分区数据)

动态分区:加载数据时,自动根据指定字段的值创建分区,无需手动创建分区目录,适合批量加载多日期、多地区的分区数据:

-- 开启动态分区(默认关闭)set hive.exec.dynamic.partition=true;-- 非严格模式(允许所有分区字段动态生成,新手推荐)set hive.exec.dynamic.partition.mode=nonstrict;-- 最大动态分区数(避免过多分区导致性能问题,可根据需求调整)set hive.exec.max.dynamic.partitions=10000;set hive.exec.max.dynamic.partitions.pernode=10000;

(3)修复分区(关键步骤,避免查询不到数据)

手动上传分区数据后,Hive的元数据(记录表结构、分区信息)不会自动更新,需执行修复命令,同步元数据与HDFS中的分区数据:

msck repair table fact_user_trade;

五、Hive查询实操:基础查询+聚合分析(高频场景)

HQL(Hive查询语言)与SQL语法高度兼容,新手可直接复用SQL经验,以下是大数据场景中最常用的查询案例,基于前面创建的dim_user_info(用户表)和fact_user_trade(交易分区表):

1. 基础条件查询(无聚合,简单筛选)

-- 1. 查询北京女用户的姓名,取前10条(限制结果条数,避免返回过多数据)select user_name from dim_user_info where city='beijing'and sex='female' limit 10;-- 2. 查询2019年3月24日购买了food类商品的用户名、购买数量和支付金额(不聚合,返回明细)select user_name, piece, pay_amount from fact_user_trade where dt='2019-03-24'and goods_category='food';-- 3. 统计用户ELLA在2018年的总支付金额和最近、最远两次消费间隔天数selectsum(pay_amount) as total_pay,        datediff(max(from_unixtime(pay_time, 'yyyy-MM-dd')), min(from_unixtime(pay_time, 'yyyy-MM-dd'))) as day_interval from fact_user_trade whereyear(dt)='2018'and user_name='ELLA';

2. 聚合查询(group by + having,统计分析)

聚合查询是大数据分析的核心,用于统计汇总数据,group by用于分组,having用于过滤聚合结果(区别于where过滤行数据):

-- 1. 查询2019年1月到4月,每个品类有多少人购买,累计支付金额是多少select goods_category, count(distinct user_name) as total_user,  -- 去重统计购买人数(避免同一用户多次购买重复计数)sum(pay_amount) as total_pay             -- 累计支付金额from fact_user_trade where dt between'2019-01-01'and'2019-04-30'groupby goods_category;-- 2. 查询2019年4月支付金额超过5万元的用户(筛选聚合后的结果)select user_name, sum(pay_amount) as total_pay from fact_user_trade where dt between'2019-04-01'and'2019-04-30'groupby user_name havingsum(pay_amount) >50000;-- 3. 查询2018年购买的商品品类在两个以上的用户数(子查询+聚合)selectcount(tmp.user_name) as total_user from (select user_name, count(distinct goods_category) as category_count from fact_user_trade whereyear(dt)='2018'groupby user_name havingcount(distinct goods_category) >2-- 筛选购买品类超过2个的用户) tmp;  -- 子查询结果作为临时表,统计符合条件的用户数

3. 排序查询(order by,按指定字段排序)

用于对查询结果排序,常与limit配合使用,获取TopN数据:

-- 查询2019年4月支付金额最多的用户前5名(降序排序)select user_name, sum(pay_amount) as total_pay from fact_user_trade where dt between'2019-04-01'and'2019-04-30'groupby user_name orderby total_pay desc-- desc:降序(从大到小),asc:升序(从小到大,默认)limit 5;

六、Hive常用函数(高频实操,提升效率)

Hive提供了大量内置函数,适配大数据处理场景(时间转换、字符串处理、JSON解析等),无需手动编写复杂逻辑,以下是最常用的6个函数,附实操案例:

1. from_unixtime:时间戳转换成日期字符串

用于将bigint类型的时间戳,转换为指定格式的日期字符串,高频用于时间维度分析:

-- 将支付时间戳转换为“年-月-日 时:分:秒”格式select from_unixtime(pay_time, 'yyyy-MM-dd hh:mm:ss'as pay_datetime from fact_user_trade limit 10;

2. unix_timestamp:日期字符串转换成时间戳

from_unixtime相反,将指定格式的日期字符串,转换为bigint类型的时间戳:

-- 将日期字符串“2019-03-24”转换为时间戳select unix_timestamp('2019-03-24''yyyy-MM-dd'as pay_ts from dual;  -- dual:Hive虚拟表,用于无表查询(仅测试函数)

3. datediff:计算两个日期的时间差(天数)

语法:datediff(日期1, 日期2),返回“日期1 - 日期2”的天数差,用于计算时间间隔:

-- 计算用户首次激活时间与参照时间(2019-04-01)的间隔天数select user_name, datediff('2019-4-1', to_date(firstactivetime)) as active_interval from dim_user_info limit 10;

4. if/case when:条件判断函数

用于根据条件返回不同的值,适配分类统计场景,case when适合多条件,if适合二值判断:

-- (1)case when:多条件分组,统计不同年龄段的用户数selectcasewhen age <20then'20岁以下'when age <30then'20-30岁'when age <40then'30-40岁'else'40岁以上'endas age_seg,count(distinct user_id) as total_user from dim_user_info groupbycasewhen age <20then'20岁以下'when age <30then'20-30岁'when age<40then'30-40岁'else'40岁以上'end;-- (2)if:二值判断,统计不同性别、不同等级的用户数量select sex,        if(level >5'高等级''低等级'as level_type, count(distinct user_id) as total_user from dim_user_info groupby sex, if(level >5'高等级''低等级');

5. substr:字符串取子串

语法:substr(字符串, 起始位置, 长度),起始位置从1开始,用于截取字符串中的指定内容(如年月、手机号前缀):

-- 截取首次激活时间的“年月”(如2018-01),统计每个月激活的新用户数select substr(firstactivetime, 17as active_month, count(distinct user_id) as new_user_count from dim_user_info groupby substr(firstactivetime, 17);

6. get_json_object:从JSON字符串中提取指定key的值

用于解析string类型的JSON数据,提取指定key对应的value,高频用于处理扩展字段中的JSON数据:

-- 示例1:从extra1(JSON字符串)中提取手机品牌,统计不同手机品牌的用户数select get_json_object(extra1, '$.phonebrand'as phone_brand, count(distinct user_id) as total_user from dim_user_info groupby get_json_object(extra1, '$.phonebrand');-- 示例2:从map类型字段extra2中提取手机品牌(直接通过key访问,更简洁)select extra2['phonebrand'as phone_brand, count(distinct user_id) as total_user from dim_user_info groupby extra2['phonebrand'];

✅ 小提示:MySQL中对应的JSON解析函数名叫json_extract,与Hive的get_json_object功能一致,可对比记忆。

七、常见问题与避坑指南(新手必看)

新手操作Hive时,很容易遇到以下问题,提前记牢避坑技巧,避免浪费时间排查:

  1. 1. 连接Hive失败:检查Hive服务是否启动、Hadoop集群是否正常运行,环境变量(如HIVE_HOME)是否配置正确;
  2. 2. 分区表查询无结果:手动上传分区数据后,未执行msck repair table 表名修复元数据,导致Hive无法识别分区;
  3. 3. 数据解析错乱:建表时指定的分隔符(如fields terminated by '\t')与实际数据的分隔符不一致,需核对数据格式调整;
  4. 4. 动态分区失败:未开启动态分区参数,或分区字段的值格式错误(如日期格式不是yyyy-MM-dd),需检查参数配置和数据格式;
  5. 5. 查询效率极低:未使用分区字段过滤数据,导致全量扫描HDFS中的海量数据,尽量通过dt等分区字段缩小查询范围;
  6. 6. 复合类型取值错误:map类型用[]取值(如extra2['phonebrand']),struct类型用.取值(如user_info.first_name),不要混淆。

八、总结

本节课我们完整讲解了Hive的核心知识点:从Hive的定位、核心特性,到前置环境准备、建库建表、数据加载,再到查询实操与常用函数,覆盖了大数据离线分析的全流程,完全对标上一篇MySQL文档的结构和风格,新手可快速上手。

核心总结:Hive的核心价值是“用SQL处理大数据”,通过将HDFS数据映射为表、将HQL转换为分布式任务,降低了大数据处理的技术门槛,无需掌握Java、Scala,只要会写SQL,就能处理TB/PB级海量数据。它适合离线批量分析场景,是大数据生态中数据仓库建设的核心工具。

后续我们还会讲解Hive的高级特性(如外部表、分桶表、数据倾斜优化),帮大家进一步提升大数据处理效率。建议大家课后结合实际数据集动手实操,熟悉HQL语法与函数使用,真正将知识转化为实战能力~

AI工具,提高学习,工作效率神器

国内直接使用顶级AI工具

谷歌浏览器访问:https://www.nezhasoft.cloud/r/vMPJZr

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-03-27 13:02:19 HTTP/2.0 GET : https://f.mffb.com.cn/a/478300.html
  2. 运行时间 : 0.081244s [ 吞吐率:12.31req/s ] 内存消耗:5,280.26kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=cf8507ac1c2b631787bc043a50de3664
  1. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/public/index.php ( 0.79 KB )
  2. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/autoload.php ( 0.17 KB )
  3. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_real.php ( 2.49 KB )
  4. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/platform_check.php ( 0.90 KB )
  5. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/ClassLoader.php ( 14.03 KB )
  6. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_static.php ( 4.90 KB )
  7. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper.php ( 8.34 KB )
  8. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/helper.php ( 2.19 KB )
  9. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/helper.php ( 1.47 KB )
  10. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/stubs/load_stubs.php ( 0.16 KB )
  11. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Exception.php ( 1.69 KB )
  12. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Facade.php ( 2.71 KB )
  13. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/deprecation-contracts/function.php ( 0.99 KB )
  14. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap.php ( 8.26 KB )
  15. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap80.php ( 9.78 KB )
  16. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/Resources/functions/dump.php ( 1.49 KB )
  17. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-dumper/src/helper.php ( 0.18 KB )
  18. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/VarDumper.php ( 4.30 KB )
  19. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/App.php ( 15.30 KB )
  20. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Container.php ( 15.76 KB )
  21. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/container/src/ContainerInterface.php ( 1.02 KB )
  22. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/provider.php ( 0.19 KB )
  23. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Http.php ( 6.04 KB )
  24. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Str.php ( 7.29 KB )
  25. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Env.php ( 4.68 KB )
  26. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/common.php ( 0.03 KB )
  27. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/helper.php ( 18.78 KB )
  28. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Config.php ( 5.54 KB )
  29. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/app.php ( 0.95 KB )
  30. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cache.php ( 0.78 KB )
  31. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/console.php ( 0.23 KB )
  32. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cookie.php ( 0.56 KB )
  33. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/database.php ( 2.48 KB )
  34. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Env.php ( 1.67 KB )
  35. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/filesystem.php ( 0.61 KB )
  36. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/lang.php ( 0.91 KB )
  37. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/log.php ( 1.35 KB )
  38. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/middleware.php ( 0.19 KB )
  39. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/route.php ( 1.89 KB )
  40. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/session.php ( 0.57 KB )
  41. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/trace.php ( 0.34 KB )
  42. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/view.php ( 0.82 KB )
  43. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/event.php ( 0.25 KB )
  44. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Event.php ( 7.67 KB )
  45. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/service.php ( 0.13 KB )
  46. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/AppService.php ( 0.26 KB )
  47. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Service.php ( 1.64 KB )
  48. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Lang.php ( 7.35 KB )
  49. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/lang/zh-cn.php ( 13.70 KB )
  50. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/Error.php ( 3.31 KB )
  51. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/RegisterService.php ( 1.33 KB )
  52. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/services.php ( 0.14 KB )
  53. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/PaginatorService.php ( 1.52 KB )
  54. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ValidateService.php ( 0.99 KB )
  55. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ModelService.php ( 2.04 KB )
  56. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Service.php ( 0.77 KB )
  57. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Middleware.php ( 6.72 KB )
  58. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/BootService.php ( 0.77 KB )
  59. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Paginator.php ( 11.86 KB )
  60. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/Validate.php ( 63.20 KB )
  61. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Model.php ( 23.55 KB )
  62. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Attribute.php ( 21.05 KB )
  63. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/AutoWriteData.php ( 4.21 KB )
  64. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Conversion.php ( 6.44 KB )
  65. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/DbConnect.php ( 5.16 KB )
  66. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/ModelEvent.php ( 2.33 KB )
  67. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/RelationShip.php ( 28.29 KB )
  68. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Arrayable.php ( 0.09 KB )
  69. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Jsonable.php ( 0.13 KB )
  70. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/contract/Modelable.php ( 0.09 KB )
  71. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Db.php ( 2.88 KB )
  72. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/DbManager.php ( 8.52 KB )
  73. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Log.php ( 6.28 KB )
  74. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Manager.php ( 3.92 KB )
  75. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerTrait.php ( 2.69 KB )
  76. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerInterface.php ( 2.71 KB )
  77. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cache.php ( 4.92 KB )
  78. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/simple-cache/src/CacheInterface.php ( 4.71 KB )
  79. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Arr.php ( 16.63 KB )
  80. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/driver/File.php ( 7.84 KB )
  81. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/Driver.php ( 9.03 KB )
  82. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php ( 1.99 KB )
  83. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/Request.php ( 0.09 KB )
  84. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Request.php ( 55.78 KB )
  85. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/middleware.php ( 0.25 KB )
  86. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Pipeline.php ( 2.61 KB )
  87. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/TraceDebug.php ( 3.40 KB )
  88. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/middleware/SessionInit.php ( 1.94 KB )
  89. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Session.php ( 1.80 KB )
  90. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/driver/File.php ( 6.27 KB )
  91. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/SessionHandlerInterface.php ( 0.87 KB )
  92. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/Store.php ( 7.12 KB )
  93. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Route.php ( 23.73 KB )
  94. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleName.php ( 5.75 KB )
  95. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Domain.php ( 2.53 KB )
  96. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleGroup.php ( 22.43 KB )
  97. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Rule.php ( 26.95 KB )
  98. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleItem.php ( 9.78 KB )
  99. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/route/app.php ( 1.72 KB )
  100. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Route.php ( 4.70 KB )
  101. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/dispatch/Controller.php ( 4.74 KB )
  102. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Dispatch.php ( 10.44 KB )
  103. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/controller/Index.php ( 4.81 KB )
  104. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/BaseController.php ( 2.05 KB )
  105. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/facade/Db.php ( 0.93 KB )
  106. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/connector/Mysql.php ( 5.44 KB )
  107. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/PDOConnection.php ( 52.47 KB )
  108. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Connection.php ( 8.39 KB )
  109. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/ConnectionInterface.php ( 4.57 KB )
  110. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/builder/Mysql.php ( 16.58 KB )
  111. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Builder.php ( 24.06 KB )
  112. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseBuilder.php ( 27.50 KB )
  113. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Query.php ( 15.71 KB )
  114. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseQuery.php ( 45.13 KB )
  115. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php ( 7.43 KB )
  116. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php ( 3.26 KB )
  117. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php ( 20.07 KB )
  118. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ParamsBind.php ( 3.66 KB )
  119. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ResultOperation.php ( 7.01 KB )
  120. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/WhereQuery.php ( 19.37 KB )
  121. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php ( 7.11 KB )
  122. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php ( 2.63 KB )
  123. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/Transaction.php ( 2.77 KB )
  124. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/driver/File.php ( 5.96 KB )
  125. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php ( 0.86 KB )
  126. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/Channel.php ( 3.89 KB )
  127. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/event/LogRecord.php ( 1.02 KB )
  128. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/Collection.php ( 16.47 KB )
  129. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/View.php ( 1.70 KB )
  130. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/View.php ( 4.39 KB )
  131. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Response.php ( 8.81 KB )
  132. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/response/View.php ( 3.29 KB )
  133. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cookie.php ( 6.06 KB )
  134. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-view/src/Think.php ( 8.38 KB )
  135. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php ( 1.60 KB )
  136. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/Template.php ( 46.61 KB )
  137. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/driver/File.php ( 2.41 KB )
  138. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/contract/DriverInterface.php ( 0.86 KB )
  139. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/runtime/temp/067d451b9a0c665040f3f1bdd3293d68.php ( 11.98 KB )
  140. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.000452s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000655s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000264s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000335s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000478s ]
  6. SELECT * FROM `set` [ RunTime:0.000247s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000611s ]
  8. SELECT * FROM `article` WHERE `id` = 478300 LIMIT 1 [ RunTime:0.000896s ]
  9. UPDATE `article` SET `lasttime` = 1774587739 WHERE `id` = 478300 [ RunTime:0.002538s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.001229s ]
  11. SELECT * FROM `article` WHERE `id` < 478300 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.002842s ]
  12. SELECT * FROM `article` WHERE `id` > 478300 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000434s ]
  13. SELECT * FROM `article` WHERE `id` < 478300 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.000801s ]
  14. SELECT * FROM `article` WHERE `id` < 478300 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.000687s ]
  15. SELECT * FROM `article` WHERE `id` < 478300 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.004040s ]
0.083119s