草庐IT

order_month

全部标签

SQL:ORDER BY 两列混合,不基于优先级

我正在使用mySQL。我必须按姓氏对联系人姓名进行排序,但在没有姓氏的情况下,我按名字排序。这看起来像:ORDERBYlastname="",lastname,firstname但是,这会使姓氏出现在顶部。我想要的行为是混合名字和姓氏,就像它们来自同一领域一样。示例(假装这些是名字):A,TZ,GABC对比:AA,TBCZ,G谢谢 最佳答案 使用COALESCE和NULLIF:ORDERBYCOALESCE(NULLIF(LastName,''),FirstName),FirstName

mysql - GROUP BY 查询忽略 ORDER BY 子句

SELECTdeal_woot.*,site.woot_off,site.nameASsite_nameFROMdeal_wootINNERJOINsiteONsite.id=site_idWHEREsite_idIN(2,3,4,5,6)GROUPBYsite_idORDERBYdeal_woot.idDESCLIMIT5我想在分组前使用ORDERBY,我该如何实现? 最佳答案 使用如下子查询:SELECT*,COUNT(*)FROM(SELECT*fromactionsorderbydateDESC)ASactionsGROUP

mysql - mysql order by 内部是如何实现的?

Mysql内部是如何实现orderby的?按多列排序是否涉及对按约束排序中指定的每一列多次扫描数据集一次? 最佳答案 这是描述:http://dev.mysql.com/doc/refman/5.0/en/order-by-optimization.html除非您有行外列(BLOB或TEXT)或您的SELECT列表太大,使用这个算法:ReadtherowsthatmatchtheWHEREclause.Foreachrow,recordatupleofvaluesconsistingofthesortkeyvalueandrowpo

mysql - 连接表性能的 ORDER BY 列

我有2个1:1关系的表(但将来可能会变成1:N关系)如下:CREATETABLEarticle(article_idINT,insertedDATETIME)ENGINEInnoDB;CREATETABLEarticle_top(article_top_idINT,article_idINT,untilDATETIME)ENGINEInnoDB;我需要做的是选择首先按article_top.untilDESC排序然后按article.insertedDESC排序的文章(因此“顶部”文章位于顶部其余的从新到旧排序。我执行以下查询,速度很慢(当我跳过ORDERBY子句中的article_t

mysql - 如何优化这个简单的 JOIN+ORDER BY 查询?

我有两个mysql表:/*Tableusers*/CREATETABLEIFNOTEXISTS`users`(`Id`int(10)unsignedNOTNULLAUTO_INCREMENT,`DateRegistered`datetimeNOTNULL,PRIMARYKEY(`Id`))ENGINE=InnoDBDEFAULTCHARSET=utf8;/*Tablestatistics_user*/CREATETABLEIFNOTEXISTS`statistics_user`(`UserId`int(10)unsignedNOTNULLAUTO_INCREMENT,`Sent_Vie

mysql - LINQ MySQL Group by Year, Month, Day 选择 Year, Month, Day, Count

varres=fromrindb.myTablegrouprbynew{Year=r.DateVal.Year,Month=r.DateVal.Month,Day=r.DateVal.Day}intogletCount=g.Count()selectnew{Year=g.Key.Year,Month=g.Key.Month,Day=g.Key.Day,Count=Count};不起作用。内部异常摘录:InnerException:MySql.Data.MySqlClient.MySqlExceptionHResult=-2147467259Message=Unknowncolumn'G

mysql - JOIN 3 tables and (LIMIT 2 rows ORDER BY time DESC)

我知道这个问题已经被问过很多次了,但我在执行它时遇到了困难。我做了一个简化的例子,所以它很容易重现。我想连接3个表,但在最后一个表上我想限制为2行DESCCREATETABLE`cars`(`car_id`int(11)NOTNULLAUTO_INCREMENT,`plate`varchar(10)NOTNULL,`km`int(11)NOTNULL,`status`tinyint(1)NOTNULL,PRIMARYKEY(`car_id`))ENGINE=MyISAMDEFAULTCHARSET=latin1AUTO_INCREMENT=6;INSERTINTO`cars`(`car

mysql - ORDER BY 优化是否在下面的 SELECT 语句中生效?

我有一个要优化的SELECT语句。mysql-orderbyoptimization表示在某些情况下索引不能用于优化ORDERBY。具体点:YouuseORDERBYonnonconsecutivepartsofakeySELECT*FROMt1WHEREkey2=constantORDERBYkey_part2;让我想到,情况可能就是这样。我正在使用以下索引:UNIQUEKEY`met_value_index1`(`RTU_NB`,`DATETIME`,`MP_NB`),KEY`met_value_index`(`DATETIME`,`RTU_NB`)使用以下SQL语句:SELECT

mysql - 在 MySQL 查询中使用 ORDER BY 时如何忽略特殊字符

我有以下向Python网页提供数据的MySQL查询。在网页上,我有一个歌曲标题列表,我希望它按字母顺序排列,忽略标点符号和空格。我的MySQL数据库是UTF-8编码的,需要忽略的一些标点符号是特殊字符,比如花撇号等。SELECT*FROMTracks\JOINArtistsUSING(ArtistID)\JOINAlbumsUSING(AlbumID)\JOINSongsUSING(SongID)\ORDERBYUPPER(\REPLACE(\REPLACE(\REPLACE(\REPLACE(\REPLACE(\REPLACE(\REPLACE(\REPLACE(\REPLACE(\

mysql 'order by' 阿拉伯字母问题

我的数据库中有阿拉伯语单词:例子:أحمديحيىاحمداسعد问题是:我想让名字按名字排序。预期的结果是:احمداسعدأحمديحيى但是我得到了:أحمديحيىاحمداسعدأ在ا之前我试过了selectnamefromemporderbyname;请帮忙。 最佳答案 请检查一下您的数据库排序规则,它们应该设置为utf8_general_ci或utf8_unicode_ci。这应该可以让您正确执行orderbyetc。如果运行独立查询试试这个:SETNAMES'utf8';SETCHARACTERSETutf8;sel