草庐IT

lower_case_table_names

全部标签

php - MySQL RENAME TABLE 语句如何工作/执行?

MySQL有一个RENAMETABLE语句,允许您更改表的名称。手册中提到Therenameoperationisdoneatomically,whichmeansthatnoothersessioncanaccessanyofthetableswhiletherenameisrunning手册没有(据我所知)说明重命名是如何完成的。是否创建了表的完整副本,赋予了新名称,然后删除了旧表?还是MySQL在幕后做了一些魔术来快速重命名表?换句话说,表的大小是否会影响RENAME表语句运行的时间。是否还有其他因素可能导致重命名block时显着阻塞? 最佳答案

mysql - 如何 "insert into table (col1, col2) values (select max(id) from table2, select id from table3); "?

我正在尝试使用名为table1_table2的查找表在table1中的max(id)与table2中的所有id之间创建多对多关系。最终,table1_table2中的行将是:table1_id,table2_id30,130,230,3...30,10000我该怎么做?我试过了insertintoinsertintotable1_table2(table1_id,table2_id)values(selectmax(id)fromtable2,selectidfromtable3);和insertintoinsertintotable1_table2(table1_id,table2_

Mysql 使用 SELECT CASE 的结果存储变量

我正在学习如何使用SELECTCASE,但我不太了解,这是代码:SET@vgls=1;SET@lgls=1;SET@st=SELECTCASEWHEN@vgls=@lglsTHEN"emp"WHEN@vgls>@lglsTHEN"loc"WHEN@vgls它给我以下错误:[Err]1064-YouhaveanerrorinyourSQLsyntax;checkthemanualthatcorrespondstoyouMySQLserverversionfortherightsyntaxtousenear'SELECTCASEWHEN@vgls=@lglsTHEN"emp"WHEN@vg

java - ALTER TABLE FOREIGN KEY 从 java 到 mysql

好吧,我想在我的数据库中进行修改,所以我需要使用altertable,但java似乎无法做到这一点。这句话ALTERTABLEloansADDFOREIGNKEY(id_reader)REFERENCESreaders(id);如何执行?我是这样做的:rawStatement="ALTERTABLEloansADDFOREIGNKEY(id_reader)REFERENCESreaders(id);";currentStatement=conn.createStatement();currentStatement.execute(rawStatement);最后一行是否正确?据我所知,

python - SqlAlchemy + Mysql : Unable to drop tables due to IntegrityError

当我尝试重新初始化我的数据库时,我不断收到IntegrityError:sqlalchemy.exc.IntegrityError:(IntegrityError)(1217,'Cannotdeleteorupdateaparentrow:aforeignkeyconstraintfails')'\nDROPTABLEusers'()在我的init_db脚本中,我有:defmain(argv=sys.argv):iflen(argv)!=2:usage(argv)config_uri=argv[1]setup_logging(config_uri)settings=get_appset

php - MySQL 左连接 : Limit parent table

我正在尝试从数据库中获取结果,但将结果限制在右侧SELECTposts.text,comments.textFROMpostsLEFTJOINcommentsONcomments.postid=post.idLimit0,5如果有5条评论,上面将返回第一个帖子的5条评论。但是我想返回所有评论,但在5个帖子后停止查询。我该怎么做?抱歉,一开始我的问题有点不清楚,因为我写错了LEFTJOIN..这是我的问题的解决方案:SELECTposts.text,comments.textFROM(SELECT*FROMpostsLimit0,5)LEFTJOINcommentsONcomments.

mysql - "If value exists in table"- 有这样的东西吗?

我是mysql的新手,我需要一些帮助。我想从表中选择一个值存在的所有行,但不选择该值:例如:IDITEM--------------------1AA122S1AB2F452BB31313AA3F453F673A......类似于:SELECTID,ITEMFROMTABLE1IFItem"AA"ispresentexcept"AA"这将返回:1225,AB31,1,F45,F67,A执行此操作的实际查询是什么?谢谢 最佳答案 您可以使用group_concat()获取列表:SELECTID,group_concat(casewhe

php - Laravel 4.2 多对多关系 : Can't read from pivot table

我试图将JeffreyWay的多对多关系教程应用到我的私有(private)消息传递应用程序中,但我遇到了困难。我正在尝试获取与用户关联的2个对话,haha和hehe。但是,Laravel给我错误:Columnnotfound:1054Unknowncolumn'Conversations.user_id'in'whereclause'(SQL:select*from`Conversations`where`Conversations`.`user_id`=1)我的对话表中有这些数据:+---------+----------+|conv_id|name|+---------+----

mysql - 使用 CASE WHEN 查询

我正在尝试编写这样的查询,但出现错误。这是我第一次使用案例,所以我认为这就是问题所在。UPDATEmy_tableCASEWHENdownloadsISNULLTHENSETdownloads=1ELSESETdownloads+1ENDWHEREattachment_id=8990ANDparent_post_id=9221ORattachment_id=9211ANDparent_post_id=383 最佳答案 你可以重写如下UPDATEmy_tableSETdownloads=CASEWHENdownloadsISNULLT

具有不区分大小写文件系统的 MacOS 上的 MySQL 区分大小写表名

我已经研究了很多,我知道要使数据库表名称敏感,您必须设置变量lower_case_table_names=0。我在osX上。我在my.cnf中做了这个改变。在那之后,如果我跑select*fromusers我得到了结果。如果我运行:select*fromUsers我收到错误消息说表不存在。但是,对于特定的数据库,区分大小写不受影响。我可以使用任何我永远不会收到错误的案例。为什么?我可以查看用于导入数据库的大型sql文件,并尝试找出是否有特定指令忽略区分大小写(?)。无论如何,为什么您认为区分大小写适用于所有数据库而不是我感兴趣的数据库?其中一个区分大小写的是InnoDB。而不关心这一点