查询数据库上所有表用到图片和视频的数据,并记录到excel表

统计后台系统使用的数据库所有的表和字段用到的图片和视频。所以数据的图片和视频规范下图片和视频的前缀很重要,便于统计。数据的图片和视频地址经常有后缀,所以存储时建议存储去掉后缀的。

const ossProcessParams = [

'?x-oss-process=video/snapshot,t_1000,m_fast',

'?x-oss-process=video/snapshot,t_1000,f_jpg',

'?x-oss-process=video/snapshot,t_2000,f_jpg',

'?x-oss-process=video/snapshot,t_3000,f_jpg'

];

查询数据库上所有表用到图片和视频的数据,并记录到excel表(数据库数据文件表)。

导入头文件:

复制代码
const FspConstant = require('@app/tools/fsp_constant.js');
const Tool = require('@app/tools/common_tool.js');
const msgCode = require('@app/config/error_config.js');
const Excel = require('exceljs');
const fs = require('fs');
const fspTool = require('@app/connections/rent/fsp_tool.js');
const AdModel = fspTool.model('AdModel');
const fspUser = require('@app/connections/rent/fsp_user.js');
const CompanyAccountModel = fspUser.model('CompanyAccountModel');

具体实现代码:

复制代码
//获取数据库的所有图片和视频地址
DeleteRepeatImageVideoTool.getDBImageVideoUrl = async function() {
    let allFiles = [];
    
    let adModelList = await AdModel.find({img: {$nin: [null, '', []]}}, '-_id img').lean().exec();
    adModelList.forEach(item0 =>{
        if(Tool.checkNotEmptArray(item0.img)){
            item0.img.forEach(item =>{
                if(Tool.checkNotEmptString(item)){
                    allFiles.push({db_name: 'AdModel', url: item, field: 'img', field_str: JSON.stringify(item0.img)});
                }
            });
        }
    });
    let companyAccountModelList = await CompanyAccountModel.find({$or: [{business_license_url: {$nin: [null, '']}}, {logo_url: {$nin: [null, '']}}]}, '-_id business_license_url logo_url').lean().exec();
    companyAccountModelList.forEach(item =>{
        if(Tool.checkNotEmptString(item.business_license_url)){
            allFiles.push({db_name: 'CompanyAccountModel', url: item.business_license_url, field: 'business_license_url', field_str: JSON.stringify(item.business_license_url)});
        }
        if(Tool.checkNotEmptString(item.logo_url)){
            allFiles.push({db_name: 'CompanyAccountModel', url: item.logo_url, field: 'logo_url', field_str: JSON.stringify(item.logo_url)});
        }
    });

    
    allFiles = allFiles.filter(item => 
        item.url && item.url.startsWith('https://test.oss-cn-hangzhou.aliyuncs.com')
    );

    if(Tool.checkNotEmptArray(allFiles)){
        let excel = Tool.makeExcel(allFiles, ['db_name', 'url', 'field', 'field_str'], {
            db_name: '数据库名称',
            url: '文件地址',
            field: '字段',
            field_str: '字段详情',
        });
        return {excel, fileCount: allFiles.length};
    }else{
        return {fileCount: 0};
    }
};
相关推荐
我叫汪枫2 小时前
在后台管理系统中,如何递归和选择保留的思路来过滤菜单
开发语言·javascript·node.js·ecmascript
技术钱2 小时前
nodejs使用RustFS容器服务搭建对象存储oss
node.js·egg
CircleMouse6 小时前
如何设置wps单元格下拉选项设置
excel·wps
大貔貅喝啤酒8 小时前
接口测试_Postman(详细版)
javascript·测试工具·node.js·自动化·postman
桜吹雪8 小时前
Langchain.js官方文档:构建具备按需加载技能的 SQL 助手
javascript·人工智能·node.js
zhangjin122211 小时前
kettle插件-excel插件,kettle读取excel动态表头,kettle根据列名读取excel
excel·kettle·kettle excel插件·kettle 动态excel
拾贰_C14 小时前
【node.js | Ubuntu | update】如何升级旧的nodejs本版至最新;如何升级npm
ubuntu·npm·node.js
湖边看客15 小时前
在 Windows PowerShell 里给 Node.js 设置内存上限
node.js
zhensherlock16 小时前
Protocol Launcher 系列:Beorg 高效任务管理的协议支持
前端·javascript·typescript·node.js·自动化·github·js
杨云龙UP16 小时前
Docker 部署 MongoDB 6.0 数据库每日自动备份实践:本地 + 异地保留 7 天_20260429
linux·运维·数据库·mongodb·docker·容器·centos