Solved

MySQL Error message: SQLSTATE[42000]: Syntax error or access violation: 1118 Row size too large (> 8126)

Posted on 2015-01-05
6
850 Views
Last Modified: 2016-06-17
Hi,

I have never seen this error message before - and am struggling to find a solution!

CDbCommand failed to execute the SQL statement: SQLSTATE[42000]: Syntax error or access violation: 1118 Row size too large (> 8126).

The offending row in the table was varchar 500, so the first thing I did was change that to LONGTEXT in the vain hope this would help - but to no avail.

The error message goes on to say "Changing some columns to TEXT or BLOB or using ROW_FORMAT=DYNAMIC or ROW_FORMAT=COMPRESSED may help. In current row format, BLOB prefix of 768 bytes is stored inline."

There is unsual (at all) about the text being entered for this row and I've got other columns which are LONGTEXT with no problem at all !

Any help much appreciated !!!
0
Comment
Question by:daisydoos
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
  • 2
6 Comments
 
LVL 83

Expert Comment

by:Dave Baldwin
ID: 40531073
How are you doing the insert?  What programming language?  And what version of MySQL are you using?
0
 
LVL 143

Expert Comment

by:Guy Hengel [angelIII / a3]
ID: 40531075
can you please show the full table description.
also, do you maybe have some trigger on the table that does something else behind?
0
 

Author Comment

by:daisydoos
ID: 40531178
Hi,

Many thanks for getting back to me. I'm using PHP. MySQL version is  5.5.35

Doesn't make any diffrence if I enter the data via the site admin or directly using PhpMyAdmin - get the same error emssage.

I've included the full table schema below - the offending columns are eg homeRightCol4 which as you can see I've now set to LONGTEXT (it was originally VARCHAR 500) ...

I have never come across this error before!!

Many thanks in advance!

CREATE TABLE IF NOT EXISTS `site_page` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `moduleNameForSearch` char(4) NOT NULL DEFAULT 'page',
  `itemOrCatForSearch` varchar(4) NOT NULL DEFAULT 'cat',
  `name` varchar(255) NOT NULL,
  `indexID` varchar(255) NOT NULL,
  `type` int(3) NOT NULL DEFAULT '1',
  `meta_title` varchar(255) DEFAULT NULL,
  `meta_description` mediumtext,
  `meta_keywords` tinytext,
  `longdesc` longtext,
  `shortdesc` mediumtext,
  `homePageOnly` mediumtext NOT NULL,
  `homeVideo` mediumtext NOT NULL,
  `homeTopR1` mediumtext NOT NULL,
  `homeTopR2` mediumtext NOT NULL,
  `homeTopR3` mediumtext NOT NULL,
  `homeLeftCol1` mediumtext NOT NULL,
  `homeLeftCol2` mediumtext NOT NULL,
  `homeLeftCol3` mediumtext NOT NULL,
  `homeMidCol1` mediumtext NOT NULL,
  `homeMidCol2` mediumtext NOT NULL,
  `homeMidCol3` mediumtext NOT NULL,
  `homeMidCol4` mediumtext NOT NULL,
  `homeRightCol1` mediumtext NOT NULL,
  `homeRightCol2` mediumtext NOT NULL,
  `homeRightCol3` mediumtext NOT NULL,
  `homeRightCol4` longtext NOT NULL,
  `youTubeCode` mediumtext NOT NULL,
  `video_title` varchar(255) NOT NULL,
  `video_thumbnail_loc` varchar(400) NOT NULL,
  `video_file` varchar(400) NOT NULL,
  `video_duration` int(9) NOT NULL,
  `video_description` varchar(700) NOT NULL,
  `parent` int(3) NOT NULL,
  `level` int(2) NOT NULL DEFAULT '0',
  `public` int(1) NOT NULL DEFAULT '1',
  `inMainMenu` int(1) NOT NULL DEFAULT '1',
  `inSubMenu` int(1) NOT NULL DEFAULT '1',
  `inFooter` int(1) NOT NULL DEFAULT '0',
  `sort` int(11) NOT NULL DEFAULT '0',
  `visible` int(1) NOT NULL DEFAULT '1',
  `inSearchResults` int(1) NOT NULL DEFAULT '1',
  `inSiteMap` int(1) NOT NULL DEFAULT '1',
  `securePage` int(1) NOT NULL DEFAULT '1',
  `module` int(3) NOT NULL DEFAULT '1',
  `lang_id` int(3) NOT NULL DEFAULT '1',
  `site_id` int(3) NOT NULL DEFAULT '1',
  `multiLingual` int(1) NOT NULL DEFAULT '1',
  `multiSite` int(1) NOT NULL DEFAULT '0',
  `externalUrl` varchar(255) DEFAULT NULL,
  `created` datetime NOT NULL,
  `updated` datetime NOT NULL,
  `create_user_id` int(3) NOT NULL,
  `update_user_id` int(3) NOT NULL,
  PRIMARY KEY (`id`),
  KEY `type` (`type`),
  KEY `module` (`module`),
  KEY `lang_id` (`lang_id`),
  KEY `site_id` (`site_id`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=60 ;
0
 
LVL 143

Accepted Solution

by:
Guy Hengel [angelIII / a3] earned 500 total points
ID: 40531224
the "error" is not in the table definition "per se", but in the total data volume per row.

to "fix" this, you will need to split the table into several tables.

my suggestion would be to move:
`homePageOnly` mediumtext NOT NULL,
  `homeVideo` mediumtext NOT NULL,
  `homeTopR1` mediumtext NOT NULL,
  `homeTopR2` mediumtext NOT NULL,
  `homeTopR3` mediumtext NOT NULL,
  `homeLeftCol1` mediumtext NOT NULL,
  `homeLeftCol2` mediumtext NOT NULL,
  `homeLeftCol3` mediumtext NOT NULL,
  `homeMidCol1` mediumtext NOT NULL,
  `homeMidCol2` mediumtext NOT NULL,
  `homeMidCol3` mediumtext NOT NULL,
  `homeMidCol4` mediumtext NOT NULL,
  `homeRightCol1` mediumtext NOT NULL,
  `homeRightCol2` mediumtext NOT NULL,
  `homeRightCol3` mediumtext NOT NULL,
  `homeRightCol4` longtext NOT NULL,

into 1 table that "translates all those columns into rows" with:
`site_page_id' (foreign key)
section_key varchar(50) not null
section_data longtext

and do like this;
id  , 'homePageOnly',  ...
id  , 'homeVideo',  ...
etc ....

this technique will then not only avoid the error, but also make it much simpler to add new "columns" to your code: just adding a new row without having to change the "schema"
0
 

Author Comment

by:daisydoos
ID: 40531284
Hi,

Many thanks for getting back with this solution - that would make sense as the problem only occurred after adding a bunch of new rows. I was not aware of this restriction!
0

Featured Post

Complete VMware vSphere® ESX(i) & Hyper-V Backup

Capture your entire system, including the host, with patented disk imaging integrated with VMware VADP / Microsoft VSS and RCT. RTOs is as low as 15 seconds with Acronis Active Restore™. You can enjoy unlimited P2V/V2V migrations from any source (even from a different hypervisor)

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Foreword This article was written many years ago, in the days when PHP supported the MySQL extension (http://php.net/manual/en/function.mysql-connect.php).  Today (http://php.net/manual/en/migration70.removed-exts-sapis.php) you would not use MySQL…
This article shows the steps required to install WordPress on Azure. Web Apps, Mobile Apps, API Apps, or Functions, in Azure all these run in an App Service plan. WordPress is no exception and requires an App Service Plan and Database to install
Finds all prime numbers in a range requested and places them in a public primes() array. I've demostrated a template size of 30 (2 * 3 * 5) but larger templates can be built such 210  (2 * 3 * 5 * 7) or 2310  (2 * 3 * 5 * 7 * 11). The larger templa…
How to Install VMware Tools in Red Hat Enterprise Linux 6.4 (RHEL 6.4) Step-by-Step Tutorial

734 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question