草庐IT

delete_keys

全部标签

mysql - 当索引不适合 key_buffer 时快速 MySQL 批量加载

这里有一个关于如何正确配置mysql(myisam)以快速执行批量插入(加载数据infile)的问题。有6Gb的文本文件要导入,1500万行,16列(一些int,一些varchar(255),一个varchar(40),一个char(1)一些日期时间,一个mediumtext)。相对my.conf设置:key_buffer=800Mmax_allowed_packet=160Mthread_cache_size=80myisam_sort_buffer_size=400Mbulk_insert_buffer_size=400Mdelay_key_write=ONdelayed_inse

mysql - 数据库迁移 : auto-incremented foreign key trouble

我正在尝试将一些数据从旧的MySQL数据库简单地迁移到新的MySQL数据库。我要迁移的数据来自一个论坛,所以有两个表:threads和posts。在我遇到一些棘手的自动递增外键关系之前,我一直做得很好。数据库架构(简化到重要部分):threads(id,title,user_id,created_at,updated_at)posts(id,thread_id,user_id,body,created_at,updated_at)如您所见,thread_id是一个外键,对应帖子所属线程的id。问题就在这里:新数据库中已经有主题和帖子,并且主键是自动递增。不难看出问题出在哪里:两个数据集

mysql - [MySQL] : DELETE rows from two dependent tables

我正在尝试根据第三个表ID删除两个相关表中的所有行。表结构:Transaction-Transaction_ID(primary)-TimestampPurchase-Item_ID-Transaction_ID-Purchase_ID(primary)Item-Item_ID(primary)-Client_ID我想从交易/购买中删除与项目中的Client_ID匹配的所有行。听起来很简单……即使是我的新手也能理解……DELETEdbName.tFROMdbName.TransactiontJOINdbName.PurchasepONp.Transaction_ID=t.Transac

MySQL INSERT IGNORE 或 ON DUPLICATE KEY DO_NOTHING

已经搜索过此类主题并找到了2个不同的解决方案,但没有一个有效。我的表有结构|ID(auto_incrementprimary_key)|UID(整数)|FAV_ID(整数)|如果UID和FAV_ID(两者)已经存在,我需要向这个FAV_TABLE插入新记录。我的查询示例:INSERTINTOFAV_TABLE(uid,fav_id)VALUES($u_id,$s_id)ONDUPLICATEKEYUPDATEuid=uid或者这个INSERTIGNOREFAV_TABLE(uid,fav_id)VALUES($u_id,$s_id);正如mysql手册所述,仅当PRIMARY_KEY相

PhpMyAdmin 导出不包括 PRIMARY KEY 作为 mysqldump

与PhpMyAdmin同表结构导出:`DROPTABLEIFEXISTS`test_apprentis`;CREATETABLEIFNOTEXISTS`test_apprentis`(`a_id`smallint(10)NOTNULL,`a_promo_id`smallint(11)NOTNULL,`a_cursus`smallint(10)DEFAULTNULL)ENGINE=MyISAMAUTO_INCREMENT=3665DEFAULTCHARSET=utf8;`Exportwithmysqldump:DROPTABLEIFEXISTS`test_apprentis`;/*!40

sql - MySQL - 在两列上为 ON DUPLICATE KEY 创建 UNIQUE 索引

我有一个包含4列的表格。我希望能够在创建时插入或更新值列(我不关心索引行ID)。CREATTABLEtablename(id,(primary)user_id,(index)setting_id,(index)value(index));最初我打算在每次要保存值时运行“REPLACEINTO...”查询。但后来我readabouttheproblems而是选择了INSERTINTO...ONDUPLICATEKEYUPDATE。问题是我没有用于“INSERTINTO...ONDUPLICATEKEYUPDATE”的单列来确定这是一个新行还是有一个现有行需要更新.所以我想我会使用一个UN

java - hibernate : Foreign key constraint violation problem

我的代码中有一个com.mysql.jdbc.exceptions.MySQLIntegrityConstraintViolationException(使用Hibernate和Spring),我不知道为什么。我的实体是Corpus和Semspace,并且在我的hibernate映射配置中定义了从Semspace到Corpus的多对一关系:[...]产生异常的Java代码是:Corpuscorpus=Spring.getCorpusDAO().getCorpusById(corpusId);Semspacesemspace=newSemspace();semspace.setCorpu

mysql - 错误查询 : DELETE and LEFT JOIN

DELETEFROMprogramScheduleLEFTJOINprogramONprogramSchedule.pid=program.idWHEREprogram.channel_id=10我收到这个错误:#1064-YouhaveanerrorinyourSQLsyntax;checkthemanualthatcorrespondstoyourMySQLserverversionfortherightsyntaxtousenear'LEFTJOINprogramONprogramSchedule.pid=program.id'atline1为什么?

mysql - BLOB/TEXT 列 'value' 用于没有 key 长度的 key 规范

我开发了一个扩展,在1.6之前在Magento上运行良好(我正在尝试企业版,我认为社区有同样的问题,因为它有相同的代码)。在我的安装脚本中,我调用了$installer->createEntityTables($this->getTable('alphanum/info'));。安装进行得很好,直到涉及到_text实体表。它在那里崩溃了!事实证明,当我记录sql并通过PHPmyadmin运行它时,这是错误:BLOB/TEXTcolumn'value'usedinkeyspecificationwithoutakeylength。我查看了那里的代码,这就是试图在值列上生成索引的原因:->

mysql - 在没有 key 长度的 key 规范中使用的 Rails BLOB/TEXT 列

我正在尝试运行Rails迁移,但我看到错误“key规范中使用的BLOB/TEXT列没有key长度”...但是,我在迁移类中指定了长度。从迁移生成SQL语句时,Rails似乎忽略了这一点。有什么线索吗?这是我的迁移类:classAddIndexToAccounts5enddefself.downremove_index:TACCOUNT,:NAMEXendend这是错误输出。它似乎已经看到了长度规范,但它并没有出现在它生成的SQL语句中:**[out::192.168.10.7]--add_index(:TACCOUNT,:NAMEX,{:length=>5})**[out::192.1