草庐IT

order_index

全部标签

sql - SQL 中的 ORDER BY

我有一个字符串类型的列,其中包含以下行中的值:1-11-51-141-71-3现在,如果我在该列上使用ORDERBY,我得到的顺序为:1-11-141-31-51-7将其排序为1-1,1-3,1-5,1-7,1-14的正确方法是什么谢谢你的时间 最佳答案 假设您的第一个字符也可能不同:orderbyconvert(substr(my_field,1,locate(my_field,'-')-1)asint),convert(substr(my_field,locate(my_field,'-')+1)asint)

php - 使用 ORDER BY 按值排序?

澄清一下,你能用这种方式使用MySQL来排序吗?ORDERBYCompanyID=XXXDESC我想做的是使用一个sql查询对X=Y的所有内容进行排序,在本例中,CompanyID=XXX。CompanyID不是XXX的所有值都应该出现在CompanyID=XXX的所有结果之后。我不想限制我的查询,但我确实想将特定公司排在其他列表之上。 最佳答案 ORDERBYFIELD(CompanyID,'google','apple','microsoft')ASC谷歌=第一微软=第三剩下的=最后

php - MySQL Order by,然后更新 Inner Join

我有一个表categories,其中包含列ID和ParentID我想添加一个名为Level的字段,它说明每个类别在类别树中的级别。我想我找到了我的解决方案,但它是在sql而不是mysql中。所以我一直在将它转换为正确的语法。但是,我认为我错过了一步。所以,这是我的代码:ALTERTABLEcategoriesDROPLevel;ALTERTABLEcategoriesADDLevelINTNULL;UPDATEcategoriesSETLevel=0WHEREParentIDISNULL;UPDATEcategoriesASAINNERJOINcategoriesBONA.Parent

MySQL Order By 非常慢

我知道有很多带有各种解决方案的OrderByQuestions,但我要求的是特定于我在下面设置的数据结构。我有以下2个表设置:表格设置CREATETABLE`record`(`id`INT(11)NOTNULLAUTO_INCREMENT,`file_group_id`INT(11)NOTNULL,`status_id`INT(11)NOTNULL,`title`VARCHAR(3000)NOTNULL,`date_created`DATETIMENOTNULL,`user_created`INT(11)NOTNULL,`publish_date`DATETIMENOTNULL,PRI

mysql - 在连接表列上优化 ORDER BY COALESCE

已编辑:按要求添加完整查询。本质上,我有一张帖子表,一对多地链接到一张转发表,类似于Twitter。我想加载按转发时间(如果存在)或原始帖子时间排序的帖子。但是,使用单个查询的排序过程非常慢(可能是因为COALESCE(x,y)没有充分利用MySQL索引)。两个相关表上的时间列都已编入索引。我的查询看起来像这样。SELECT*FROMPostpLEFTJOINp.repostsON...WHERE...ORDERBYCOALESCE(r.time,p.time)LIMIT0,10更准确地说(伪)因为我使用的是DAL:SELECT*FROMPostpLEFTJOINp.repostsre

MySQL的index merge(索引合并)导致数据库死锁分析与解决方案

背景在DBS-集群列表-更多-连接查询-死锁中,看到9月22日有数据库死锁日志,后排查发现是因为mysql的优化-indexmerge(索引合并)导致数据库死锁。定义indexmerge(索引合并):该数据库查询优化的一种技术,在mysql5.1之后进行引入,它可以在多个索引上进行查询,并将结果合并返回。mysql数据库的锁机制在排查问题之前,首先讲一下mysql数据库的锁机制:1加锁的基本单位是next-keylock(记录锁+间隙锁),当记录锁或者间隙锁能够解决幻读的问题,就会退化为记录锁(行锁),间隙锁。2加锁是将锁加在了索引之上,而不是数据之上。3对于当前读,索引进行加锁,当前读语句包

php - 具有复杂 ORDER BY 的 MySQL 查询

我有以下查询:SELECTid,title,adcontent,adtargetURL,locationpage,locationarg,locationid,displayorder,visible,schedstart,schedstop,created,modified,createdby,modifiedbyFROMadsORDERBYlocationpage,locationarg,locationid,title我需要按以下方式对字段进行排序:按locationpage排序,所有值为“all”的字段在前,然后按升序排序然后通过locationarg将任何NULL或空字符串值

mysql - 查询 : Tables with indexing/foregeing keys/correlated data

我目前正在使用MySQL数据库表结构。我在网上找到了一个很棒的表结构,但我不确定如何复制这样的东西。我对此很陌生,我请求帮助创建一个查询,该查询将创建所有表(具有相关数据(索引)、外键、多对多关系等)。随机我能够进行查询以选择所有字段:SELECT*FROMscheduleINNERJOINsemesterONschedule.semester_id=semester.idINNERJOINoffice_hoursONoffice_hours.schedule_id=schedule.semester_idINNERJOINfacultyONfaculty.id=office_hour

php - JOINed 表上的 GROUP BY 和 ORDER BY - 复杂且缓慢

故事是这样的……我有用户,他们有child。我想每天使用CRONJOB优惠券向在child出生日期间隔内有child的用户发送。我想知道谁将成为获得优惠券的用户以及哪个child。此外,我只想为每个child发送一张优惠券,并且该child必须是用户拥有的最小的child。我有以下表格Children+--------------------------------------+-PrimaryKey:childrenID(int)-Index:userID(int)-Index:childBirthDate(date)+--------------------------------