博客
关于我
mysql merge表合表时遇到的问题(一) 无法添加数据
阅读量:800 次
发布时间:2023-02-10

本文共 1515 字,大约阅读时间需要 5 分钟。

解决MERGE表只读状态问题

在实际工作中,我曾遇到过一个类似的问题:在创建MERGE表后,尝试手动添加数据时,提示表为只读状态。经过多次尝试和查找资料,问题依然未能解决。因此,我决定深入研究这个问题,找出最终的解决方案。

问题背景

表名为inquiry_data_2019_04,使用的是MRG_MyISAM引擎。根据网上的资料,其他人使用的表引擎是MyISAM,而修改后可以正常添加数据。因此,我开始怀疑,可能是引擎设置的问题。

表结构分析

在对比两张表的结构后,我发现自己的表结构与其他人有很大不同。具体来说:

CREATE TABLE `inquiry_data_2019_04` (    `ID` varchar(32) COLLATE utf8mb4_unicode_ci NOT NULL,    `PUSH_WAY` varchar(32) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT '推广渠道',    `KEYWORD` varchar(100) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT '关键词',    `PLAN` varchar(32) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '推广计划',    `UNIT` varchar(32) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '单元',    `QUERY_NUM` int(10) NOT NULL COMMENT '询盘数',    `HOURS` int(5) DEFAULT NULL COMMENT '时',    `DAY` int(5) NOT NULL COMMENT '日',    `MONTH` int(5) NOT NULL COMMENT '月',    `YEAR` int(6) NOT NULL COMMENT '年',    `SITEID` varchar(32) COLLATE utf8mb4_unicode_ci NOT NULL,    `CREATE_TIME` datetime DEFAULT NULL,    PRIMARY KEY (`ID`)) ENGINE=MRG_MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='询盘来源数据分析表_年_月';

发现与解决方案

  • 引擎类型问题

    最初,我发现自己的表使用的是MRG_MyISAM引擎,而其他人的表使用的是普通的MyISAM引擎。因此,我尝试将引擎类型更改为MyISAM

    ALTER TABLE `inquiry_data_2019_04` ENGINE=MyISAM

    更改后,表变为可读状态,可以正常添加数据。

  • 文件权限问题

    在更改引擎后,我发现仍然无法手动添加数据。于是,我检查了数据库的文件权限,发现*.ibd文件的权限可能过高,导致无法直接修改数据。通过修改文件的权限,确保用户有权限修改这些文件,问题得以解决。

  • 表结构的一致性

    最终,我发现自己创建的表与其他表的结构并不完全一致。因此,我根据实际需求,补充了必要的字段和约束,确保表结构与其他表保持一致。

  • 总结

    通过以上方法,我成功解决了MERGE表只读状态的问题。关键步骤包括:

    • 更改引擎类型为MyISAM
    • 修改数据库文件权限。
    • 确保表结构与其他表保持一致。

    希望以上方法能为您提供帮助!

    转载地址:http://eeffk.baihongyu.com/

    你可能感兴趣的文章
    NIH发布包含10600张CT图像数据库 为AI算法测试铺路
    查看>>
    Nim教程【十二】
    查看>>
    Nim游戏
    查看>>
    NIO ByteBuffer实现原理
    查看>>
    Nio ByteBuffer组件读写指针切换原理与常用方法
    查看>>
    NIO Selector实现原理
    查看>>
    nio 中channel和buffer的基本使用
    查看>>
    NIO_通道之间传输数据
    查看>>
    NIO三大组件基础知识
    查看>>
    NIO与零拷贝和AIO
    查看>>
    NIO同步网络编程
    查看>>
    NIO基于UDP协议的网络编程
    查看>>
    NIO笔记---上
    查看>>
    Vue3.0中的响应式原理(第九课)
    查看>>
    NIO蔚来 面试——IP地址你了解多少?
    查看>>
    NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
    查看>>
    NISP国家信息安全水平考试,收藏这一篇就够了
    查看>>
    NIS服务器的配置过程
    查看>>
    NIS认证管理域中的用户
    查看>>
    Nitrux 3.8 发布!性能全面提升,带来非凡体验
    查看>>