MySQL数据库插入数据出现
ERROR 1526 (HY000): Table has no partition for value xxx
工作的时候发现无法插入数据,报错:
ERROR 1526 (HY000): Table has no partition for value xxx

根据字面意思可以猜测大概是值已经超出了分区的范围,查询表结构发现此表创建了分区,并且设定了规则是按照ID范围存储数据,
当插入的数据最后的分区ID值要大时,报错。解决方法可以直接添加分区即可。为验证问题,创建表:

/*********************************************************/
create table test_tb3(id int auto_increment primary key,name varchar(20))
charset=utf8 
partition by  range(id) (partition p0 values less than(10),
partition p1 values less than(20));
/*********************************************************/
不断insert 数据 终于报错:
MariaDB [testDB]> insert into test_tb3(name) value('Jerry');
ERROR 1526 (HY000): Table has no partition for value 20
解决方法:
alter table test_tb3 partition by range(id) (partition p3 values less than(40));
以上添加一个名为 p3 的分区,然后存放id值为20-39的数据。
/********************************************************/
验证成功:
MariaDB [testDB]> insert into test_tb3(name) value('Rex');
Query OK, 1 row affected (0.00 sec)

MariaDB [testDB]> select max(id) from test_tb3;
+---------+
| max(id) |
+---------+
|      20 |
+---------+
1 row in set (0.00 sec)

MariaDB [testDB]>
/*******************************************************/
然后想想为什么要做这种ID的分区呢,试想,假如你数据库数据很多,数据文件很大,假如一个文件10G,假如你要查询数据,
就意味着你要读这个10G大小的文件才能SELECT你需要的值,啊咧?服务器估计会想骂你不讲人权吧?于是为了提高IO性能,应该说是数据库性能
尝试设置规则把数据文件分开存放(上面的我没弄啦)这样查询的时候就可以根据ID从不同的磁盘读取数据咯。数据库算是提升了性能吧。
来了解下怎么实现:
/******************************************************/
mysql 5.6.6以上版本支持单表指定目录,且目录权限属主和属组为mysql:mysql,根据不同的存储引擎存放的文件也有差别:
MYISAM:
.frm--->存放表结构
.myd--->存放数据
.myi--->存放索引
Innodb:
.frm--->存放表结构
.idb--->存放单个表的数据和索引
.isl--->存储表的路径名,类似软连接
1.设置参数,/etc/my.cnf加入参数配置 innodb_file_per_table = 1
2.创建表:
drop table table_td5 if exists;
create table table_td5 (id int auto_increment primary key,name varchar(30))
charset=utf8 engine=innodb
partition by range(id) (
partition p0 values less than(10)
data directory='/mysqldata/p0',
partition p1 values less than(20)
data directory='/mysqldata/p0',
partition p2 values less than(30)
data directory='/mysqldata/p2');
注意存储引擎MyISAM和InnoDB的差别在于 Innodb索引和数据都在一个文件中,而MyISAM索引和数据分开两个文件。
所以MyISAM存储引擎可以指定INDEX目录。
3.插入值ID到了30后:
MariaDB [testDB]> insert into table_td5(name) value('handsom_rex');
Query OK, 1 row affected (0.00 sec)
MariaDB [testDB]> insert into table_td5(name) value('handsom_rex');
ERROR 1526 (HY000): Table has no partition for value 30
MariaDB [testDB]> insert into table_td5(name) value('handsom_rex');
ERROR 1526 (HY000): Table has no partition for value 30
发现ID已超限制.

MySQL数据库插入数据出现 ERROR 1526 (HY000): Table has no partition for value xxx的更多相关文章

  1. ERROR 1526 (HY000): Table has no partition for value xxx

    最近,我们有些功能需要使用到基于多个字段的分区,需要同时支持oracle/mysql,但是开发人员又希望尽可能少的改动业务代码,也不愿意使用多列分区,在oracle 11g之前,不支持多列分区(12. ...

  2. Python向mysql数据库插入数据

    一.向表tcolor中插入数据的主要流程如下: import datetimeimport pymysql.cursorsconnection = pymysql.connect(host='loca ...

  3. 关于mysql数据库插入数据,不能插入中文和出现中文乱码问题

    首先,推荐一篇博客:http://www.cnblogs.com/sunzn/archive/2013/03/14/2960248.html 当时,我安装完mysql数据库后,新建一个数据库后插入数据 ...

  4. Python数据库(二)-Mysql数据库插入数据

    通过python连接mysql数据库,并插入数据 # -*- coding:utf-8 -*- __author__ = "MuT6 Sch01aR" import pymysql ...

  5. MySQL数据库使用报错ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.

    今天MySQL数据库,在使用的过程中一直报错ERROR 1820 (HY000): You must reset your password using ALTER USER statement be ...

  6. 用Python向MySQL数据库插入数据

    最近一直在学习MySQL数据库,很感兴趣.这次我做了一个简单的尝试,使用Python3.4与MySQL数据库进行交互,将一份从雪球网上下载的某股票数据上传至MySQL数据库.仅为初学者提供参考,高手请 ...

  7. C#连接mysql数据库插入数据后获取自增长主键ID值

    From: http://blog.csdn.net/zbc496218/article/details/51082983 MySqlConnection conn = new MySqlConnec ...

  8. 在控制台远程连接mysql数据库时,出现ERROR 2049 (HY000)错误

    问题的原因是,你本地的数据库版本过高,而远程的数据库版本低. 解决方法:在连接时加上  --skip-secure-auth 参数就可以了. mysql -h主机 -u用户名 -p密码 --skip- ...

  9. 向MySQL数据库插入数据出现乱码的情况分析

    (1)第一种情况在新建数据库时 (2)第二种情况就是,IDE环境里面配置编码设置为UTF-8 (3)第三种情况就是连接数据库时,没有设置编码.这个是最常规的.这个看起来很容易解决,但是需要注意MySQ ...

随机推荐

  1. Centos 7 安装nginx指定版本

    官方版本列表:http://nginx.org/download/ 1.安装 wget http://nginx.org/download/nginx-1.10.3.tar.gz tar -zxvf ...

  2. kafka消息队列、环境搭建与使用(.net framework)

    一:kafka介绍 kafka(官网地址:http://kafka.apache.org)是一种高吞吐量的分布式发布订阅的消息队列系统,具有高性能和高吞吐率. 1.1 术语介绍 BrokerKafka ...

  3. 国产网络损伤仪SandStorm -- 基本概念:什么是仿真引擎

    "仿真引擎"在网络损伤仪SandStorm(www.minismb.com)或者网络IP仿真损伤仪中是一个最基本概念,它就相当于一个由两个物理以太网口组成的"网桥&quo ...

  4. M1 MacBook安装Homebrew

    在装载M1芯片的MacBook产品上,默认是不带有homebrew这款包管理工具的,具体原因官方解释为适配问题,原有的homebrew无法与silicon Mac机型匹配.但是这并不意味着我们不可以在 ...

  5. JavaScript事件:事件处理模型(冒泡、捕获)、取消冒泡、阻止默认事件

    (一)事件处理模型---事件冒泡.捕获 (1)事件冒泡 24 <body> 25 <div class="warpper"> 26 <div clas ...

  6. u-boot 移植 --->6、引导Linux启动测试

    在引导Linux开机之前需要先清楚Linux启动的必要或者说是先决条件,这里就是提到了u-boot的作用了引用百度云---主要用于嵌入式系统的引导加载,其实在我调试下来总结一下就是初始化硬件这里的硬件 ...

  7. 写给程序员的机器学习入门 (十一) - 对象识别 YOLO - 识别人脸位置与是否戴口罩

    这篇将会介绍目前最流行的对象识别模型 YOLO,YOLO 的特征是快,识别速度非常快

  8. Storybook 最新教程

    Storybook 最新教程 Storybook is the most popular UI component development tool for React, Vue, and Angul ...

  9. React Refs All In One

    React Refs All In One https://reactjs.org/docs/react-api.html#refs Ref https://reactjs.org/docs/refs ...

  10. 二叉搜索树 & 二叉树 & 遍历方法

    二叉搜索树 & 二叉树 & 遍历方法 二叉搜索树 BST / binary search tree https://en.wikipedia.org/wiki/Binary_searc ...