草庐IT

key_press

全部标签

mysql - INSERT INTO table DEFAULT(key_col) 插入零?

我在tbl中有这个主键列:`id`INT(5)unsignedNOTNULLAUTO_INCREMENTPRIMARYKEY当我运行下面的查询时,插入零而不是下一个自动递增数字:INSERTINTO`tbl`(id,col1,...)VALUES(DEFAULT(id),"value1",...)有趣的是,这种行为是最近发生的,让我想知道我可能更改了哪些设置会导致这种情况。我首先考虑的是NO_AUTO_VALUE_ON_ZERO。我已将其添加到配置文件中的sql_mode,现在是这样的:sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLE

MySQL PRIMARY KEY 与 UNIQUE 约束

根据MySQL文档,PRIMARYKEY约束和UNIQUE约束之间的区别在于PK约束不允许NULL值,而UQ约束允许NULL值。在MySQL表中,可以为同一列创建PK和UQ!为已经具有PK约束的列创建UNIQUE约束的意义或原因是什么!?为什么MySQL允许为已经具有PK约束的列创建唯一约束? 最佳答案 作为前言,请注意主键不必是单个列:它可以由多个列组成:这称为复合键。另请注意,并非每个表都有AUTO_INCREMENT/IDENTITY列,您可以对复合内的单个列设置UNIQUE约束-无论如何都是关键。没有-但是DBMS禁止这样的

mysql - Django: 1215, 'Cannot add foreign key constraint' on model with only one field

我有一个沙拉模型:classSalad(models.Model):some_field=models.ForeignKey(Profile,on_delete=models.CASCADE,null=True)无论我如何调用类、单个字段、我用什么模型代替Profile,或者我选择的任何on_delete选项。我系统地得到错误:django.db.utils.IntegrityError:(1215,'无法添加外键约束')错误日志:Traceback(mostrecentcalllast):File"C:\Users\Div-o\AppData\Local\Programs\Pytho

mysql - 关于重复 key 更新 - 优先级

在执行INSERTINTO{tableA}SELECTa,b,cFROM{tableB}ONDUPLICATEKEYUPDATEx=y时如何评估重复键的优先级是什么?我假设MySQL首先检查表B中的元组是否与表A中的唯一/主键冲突。如果SELECT不包含主键,或者如果不存在其他重复键,则评估每个后续的UNIQUEINDEX“组”并执行相同的检查。但是,如果您的tableB具有多组唯一的多列索引,会发生什么情况?它们是否按照SHOWINDEXESFROMtableB所述自上而下评估??这是我的SHOWINDEXESFROM:Table,Non_unique,Key_name,Seq_in

MySQL 错误 1452 - 无法添加或更新子行 : a foreign key constraint fails

我查看了其他人关于此主题的问题,但似乎无法找到我的错误来源。任何帮助将不胜感激。我尽可能多地包括可能有助于找到问题的内容:CREATETABLEstocks(idINTAUTO_INCREMENTNOTNULL,user_idINT(11)UNSIGNEDNOTNULL,tickerVARCHAR(20)NOTNULL,nameVARCHAR(20),ratingINT(11),positionENUM("strongbuy","buy","sell","strongsell","neutral"),next_lookDATE,privacyENUM("public","private

mysql - 指定的 key 太长;最大 key 长度为 1000 字节

通过mySQL转储导入Joomla1.5数据库但出现错误“1071-指定的key太长;最大key长度为1000字节”罪魁祸首的sql语句是:CREATETABLE`jos_core_acl_aro`(`id`INT(11)NOTNULLAUTO_INCREMENT,`section_value`VARCHAR(240)NOTNULLDEFAULT'0',`value`VARCHAR(240)NOTNULL,`order_value`INT(11)NOTNULLDEFAULT'0',`name`VARCHAR(255)NOTNULL,`hidden`INT(11)NOTNULLDEFAU

MySQL CREATE TABLE & FOREIGN KEY 错误

我不是数据库专家,但我一直在研究这个问题,但似乎无法解决这个问题。我已经阅读了相关的文档页面(http://dev.mysql.com/doc/refman/5.5/en/innodb-foreign-key-constraints.html),但我看不出我的语法哪里有问题.ERROR1064(42000)atline84:YouhaveanerrorinyourSQLsyntax;checkthemanualthatcorrespondstoyourMySQLserverversionfortherightsyntaxtousenear'FOREIGNKEY(user_id)REFE

mysql - Ruby On Rails - Rake 模式 - 最大 key 长度为 767 字节

我正在尝试rakedb:schema:load但我收到错误Mysql2::Error:Specifiedkeywastoolong;maxkeylengthis767bytes:CREATEUNIQUEINDEX据我了解,InnoDB的索引中最多只允许767字节...如果您使用的是utf-8,则应除以3。但是当我尝试在schema.rb中设置最多100个字符(它甚至不接近767)时,错误仍然发生......schema.rbadd_index"friendly_id_slugs",["slug","sluggable_type"],:name=>"index_friendly_id_s

mysql - 运行EXPLAIN时,如果key的字段值不为null,Extra为空,是否使用了key?

在没有索引的情况下运行此EXPLAIN查询时EXPLAINSELECTexec_date,100*SUM(CASEWHENcached='no'THEN1ELSE0END)/SUM(1)cached_no,100*SUM(CASEWHENcached!='no'THEN1ELSE0END)/SUM(1)cached_yesFROMrequestsGROUPBYexec_date这是输出idselect_typetabletypepossible_keyskeykey_lenrefrowsExtra1SIMPLErequestsALLNULLNULLNULLNULL478619Using

mysql - ADD FOREIGN KEY 和 ADD CONSTRAINT fk_foreign_key 的区别

这个问题在这里已经有了答案:Differencesbetween"foreignkey"and"constraintforeignkey"(3个答案)关闭8年前。在MySQL中执行以下操作:altertableTABLE_AADDCONSTRAINTfk_id(id)REFERENCESTABLE_B(id)ONDELETECASCADEONUPDATECASCADE;做同样的事情altertableTABLE_AADDFOREIGNKEY(id)REFERENCESTABLE_B(id);除了它还在关系上添加了BTREE索引?还是它们相互补充?