草庐IT

update_by_query

全部标签

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或空字符串值

PHP/MySQL : Model repeating events in a database but query for date ranges

我正在开发一个(我打算成为的)简单的PHP/MySQL应用程序。作为其中的一部分,我希望能够对重复事件进行建模,但是我需要能够查询两个日期之间发生的所有事件(包括重复事件)。事件只有日期,一天中的时间无关紧要。我一直在研究这个问题并研究了各种方法,包括CalendarRecurring/RepeatingEvents-BestStorageMethod和Repeatingcalendareventsandsomefinalmaths.但是,我在网上找到的支持此功能的任何数据库模式示例似乎只支持查询某一天发生的事件。不支持在一定日期范围内发生的事件。作为一个抽象的例子事件表(具有某种重复

MYSQL Query比较两个查询的结果?

我目前正在为一个网站开发一个搜索功能,该功能可以在数据库中搜索特定动物。假设用户输入rabbit,搜索将通过db并显示rabbit的结果。现在假设用户输入bunny搜索将通过db但不会找到bunny的匹配项。大多数人都知道bunny的意思是rabbit,但数据库并不知道。此时我已经在同一个数据库中实现了一个MySQL同义词库来搜索用户输入的同义词。这意味着如果用户输入bunny,它将显示bunny的同义词列表。在该列表中有单词Rabbit,我试图从那里提取该单词以生成匹配项。此时我有以下内容。"SELECT`engname`FROM`searchtestdb`WHERE`engname

php - MYSQL insert or update if exists on one-way composite primary key table 单向复合主键表

我有一个用户之间的友谊表,如下所示。CREATETABLEuser_relations(pkUser1INTEGERUNSIGNEDNOTNULL,pkUser2INTEGERUNSIGNEDNOTNULL,pkRelationsTypeTINYINTUNSIGNEDNOTNULL,PRIMARYKEY(pkUser1,pkUser2),FOREIGNKEY(pkuser1)referencesusers(ID),FOREIGNKEY(pkuser2)referencesusers(ID),FOREIGNKEY(pkRelationsType)referencesuser_relati

php - Codeigniter 2 $this->db->join 与 $this->db->update 一起使用

我刚刚意识到你不能使用:$this->db->join()与$this->db->update()似乎“join”是由codeigniter执行的,但在查询中没有使用,在更新基础表后看到:$this->db->last_query();我看到没有join。然后我尝试对联接表进行更新,认为联接只会在需要时使用,但我没有工作,并告诉我错误1054“where子句中的未知列XXX”。有没有办法强制使用codeigniter?我构建软件的方式,我真的不想自己构建查询的所有不同部分(连接、位置)和调用$this->db->query()。注意:我看到了这些链接:Codeigniteractive

mysql - 代码点火器 : how to avoid db query returns last statement as key value

我在codeigniter中查询结果之前执行了几个查询:$sql_drop_temptable="...blabla...";$sql_prepare="itcreatesatemporarytable;whereIsumuplater...";$sql_summe="selectsec_to_time(sum(time_to_sec(summands)))fromworkday;";$query=$this->db->query($sql_drop_temptable);$query=$this->db->query($sql_prepare);$query=$this->db->q

MySQl 查询 : Join and Group By, 性能缓慢

我的MySQL查询有问题,我无法优化它。SELECTp.id,p.name,p.sku,p.typeFROMxm_productspLEFTJOINxm_store_productspONp.id=sp.product_idLEFTJOINxm_storesONsp.store_id=s.idWHEREs.id=1ORDERBYp.type,p.nameascLIMIT20OFFSET0这个查询很慢:Querytime2.532s如果我删除OrderBy子句,查询速度非常快:0.0001秒解释显示以下信息:+----+-------------+-------+--------+---

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

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

mysql - 使用 MySQL RAND() 来避免 ORDER BY RAND()

我在每次插入时将RAND()值存储在表中,然后运行以下查询以从表中获取随机行。selectidfromtestwhererandom_value>=RAND()LIMIT5;表中共有456行,但随机值仅选取前20-25条记录。我在上面的查询中运行了很多次,但从未得到id>21。您可以在here中找到查询和结果。 最佳答案 您的RAND()在每次循环后都会发生变化。您需要在SELECT之前修复它:SET@r:=RAND();SELECTid,@rFROMtestWHERErandom_value>=@rLIMIT5但这不是一个好的解决

mysql - 服务器上的 SQL : Saving Query Statements to a File

我正在尝试做的事情:保存MySQL用来填充我网站数据的确切查询。为此,我想将从我的数据库请求的ex:'SELECT*FROMTableWHEREX>2'保存到服务器上的文本文件中。为了避免“你为什么需要这个?”问题,数据库类(class)的一个项目要求我研究数据库是如何收集数据的,还有什么比我自己的网站更好的地方?我尝试过的:我查看了SPOOL命令,但根据我收集到的信息,这仅适用于Oracle系统。查看Tee命令,我可以将查询结果附加到文件中。为什么我的尝试没有成功:解决方案不能通过SQL查询,因为我无法精确控制数据库的填充方式。数据库从名为IMDB-Connector的连接器创建,并