【mysql – 在三个不同的列上使用MAX,WHERE和GROUP BY提高SQL查询的速度】教程文章相关的互联网学习教程文章

MySQL优化测试“ WHERE(X = 0或X = 1)”与“ WHERE X <2”【代码】

删除OR语句对性能有好处吗? 哪个编译速度更快SELECT id FROM mytable where (x=0 or x=1) 要么SELECT id FROM mytable where x<2我自己进行了测试,第二个测试速度更快.但是我不确定这是否是由于运行第一个命令时发生的缓存所致.有没有一种好的方法可以评估两个竞争查询而又不缓存并影响其他查询? EXPLAIN产生相同的输出:+----+-------------+---------+------+---------------+------+---------+------+---------+-------------...

PHP-MYSQL与多个WHERE最接近的匹配项【代码】

在我的数据库中,我有一个包含产品的表,另一个表具有与每个产品相关的标签. 当用户查看产品页面时,我想显示与他正在查看的产品“最相关”(或最接近)的产品. 假设产品带有5种不同的标签.我想获得具有相同5个标记的产品,然后具有相同5个标记的4个产品,然后具有相同5个标记的3个产品,等等… 为此,我猜测我将不得不创建一个或多个MYSQL查询,但我什至不知道从哪里开始. 匹配相同的5个标签很容易,我可以只使用WHERE tag =’?’ AND tag =...

mysql-如何忽略where子句中的条件【代码】

从表1中选择字段1 WHERE field1> = 4006 AND field1< ( 选择字段1 从表 WHERE field1> 4006 AND栏位2 =假 ORDER BY栏位1 限制1 ) 如果内部选择未返回任何记录,我希望忽略第二个条件(AND field1<).与此相关的topic解决方法:像(未经测试!)之类的东西:SELECT field1 FROM table1 WHERE field1 >= 4006 AND (field1 < (SELECT field1 FROM tableWHERE field1 > 4006AND ...

MySQL WHERE子句中的当前日期【代码】

我只想要从当前日期开始的日期.我如何在CodeIgniter中询问此问题? “ end_date”是DATETIME(Y-m-d H:i:s). 这不起作用:$this->db->select("DATE(end_date) as my_end_date", FALSE); $this->db->where('my_end_date >', date()); $q = $this->db->get('tblTest');解决方法:您需要使用PHP格式化date,以便采用MySQL想要的格式. 尝试这个:$this->db->where('end_date >', date('Y-m-d H:i:s'));您也可以为此使用MySQL的NOW().$th...

MySQL查询与别名WHERE不匹配【代码】

为什么我的sintax不正确?SELECT *,MATCH(tags,title,description) AGAINST ('asd jhbdckdsb' IN BOOLEAN MODE) AS score FROM blogs WHERE score > 0ORDER BY score DESC, insert_datetime DESC, id DESC ; 问题似乎在哪里:/解决方法:WHERE中不允许使用不可见的列和列别名,因此请使用HAVING 得分> 0,而不是WHERE

mysql-UPDATE table1 SET column1 =(SUM(table2 {&table3} WHERE table2_id1 = id1)WHERE id1 = table2_id1【代码】

我想基于主要应用于table2的总和来更新table1,但包括来自表3的单个值. table2的一列与table1的id列对应,并且总和基于它们的匹配.UPDATE table1, table2 SET table1.column1 = (SELECT SUM( (SELECT constant FROM table3) +(SELECT table2.sum_number WHERE table2.table2_id1 = table1.id) ) ) WHERE table1.id = table2.table2_id1;那对我不起作用. 提前谢谢了! 编辑:给出错误#1064 - You have an error in your SQL syntax...

mysql-where_in和find_in_set之间的区别【代码】

我正在研究一个联接查询,其中我必须从包含逗号分隔值的列中获取数据.例如allowed_activity包含1,2,3,4,5,6这是被允许的activity_id. 因此,在查询中,我正在检查是否允许当前活动,为此,我使用了where_in并在where条件中尝试了find_in_set. 这是查询的一部分:$this->db->where_in('a.allowed_activity',$activity_id); //And With FIND_IN_SET $this->db->where("FIND_IN_SET($activity_id, a.allowed_activity) !=",0);问题或困惑 当...

RAND()在MYSQL的WHERE子句中【代码】

我发现此博客文章显示了一种从表中获取随机行的方法:http://www.rndblog.com/how-to-select-random-rows-in-mysql/ 我在尝试限制的繁重的删除查询中使用了它,并且它的运行速度很快.DELETE table1 FROM table1 JOIN table2 ON table2.id = table1.salesperson_id JOIN table3 ON table3.id = table2.user_idJOIN table4 ON table3.office_id = table4.id WHERE table1.type = "Snapshot" AND table4.id = 113 OR table4.parent_id ...

子句中WHERE的MySQL问题【代码】

我在mysql中的“ where in”子句中遇到问题,我无法弄清楚出了什么问题.所以我有两个桌子… 1)座位 (int)seat_id 2)寄存器 (int)register_id (varchar)seat_ids-以逗号分隔的席位,例如102,103,104 因此,我要获取匹配结果的查询是SELECT * FROM Seats s, Registers r WHERE s.seat_id IN (r.seat_ids) GROUP BY s.seat_id有人可以找出问题所在吗?谢谢,解决方法:IN要求列表是文字列表,而不是逗号分隔的字符串.为此使用FIND_IN_SET:...

mysql-使用列别名作为排序键的Spring批处理-格式错误的“ where”语句【代码】

我正在使用Spring-batch版本3.0.6.RELEASE来查询MySQL数据库以获取一些数据,然后对其进行处理. 有关用法的详细信息: >查询提供者是MySqlPagingQueryProvider>在设置查询提供程序时,我指定查询中一列的别名作为排序键(请检查以下查询以获取更多详细信息) 查询:SELECTtarget.tx_timestamp AS event_datetime,.... FROMsome_table AS target.... WHEREtarget.tx_timestamp > :startTime AND target.tx_timestamp <= :endTime;编码:...

MYSQL中WHERE子句的情况【代码】

问题很简单,正如标题所说,但这是一种逻辑.这是我的代码CREATE TABLE `inf_brand_images` ( `id` bigint(99) NOT NULL AUTO_INCREMENT, `brand` varchar(255) NOT NULL, `thumb` text NOT NULL, `is_active` int(2) NOT NULL DEFAULT '1', `cmp_brand` varchar(1024) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=6458 DEFAULT CHARSET=latin1这是此表中的数据ID | brand | thumb |is_active| cmp_brand 1 | NI...

MySQL SELECT WHERE IN LIST和NOT IN LIST在同一SQL中【代码】

我有这个:$ids = "1,2,3,4,5";$sqlQuery = "SELECT id, moderation_dateFROM table_liveWHERE id IN (".$ids.")";$q = $this->CI->db->query($sqlQuery);if($q->num_rows() > 0) {foreach ($q->result() as $row) {$arr[] = $row;}}return $arr;如果所有ID都存在于table_live中,这将很好地工作然后返回array([id] => 1 [moderation_date] => 2012-04-11 12:55:57)....问题:如果我发送ID列表1-2-3-4-5,其中只有1-2-5与IN LIST子句...

mysql-不带WHERE语句的INT比较【代码】

我正在尝试编写一条MySQL语句,该语句将使我返回这些结果:## Name | Day 0 | Day 1 | Day 2 | Day 3 | Day 4 | Day 5 | ##Jeff | 0 | 3 | 1 | 2 | 1 | 1 | ##Larry | 1 | 1 | 4 | 4 | 1 | 0 |基于每个员工每天执行多少任务. 我的数据库表如下: 雇员 id(INT),数字(VARCHAR),名称(VARCHAR),dateStarted(VARCHAR), 项目 id(INT),数字(VARCHAR),dateEnded(DATETIME) 现在,我正在使用...

在MySQL中使用HAVING和WHERE子句之间的“OR”?【代码】

我试图使用一个简单的使用提交字段在MySQL中获取记录.更确切地说,用户输入名称(名字或姓氏或全名),服务器应返回匹配的行. 到目前为止我所做的是:SELECT * FROM people WHERE firstname LIKE '%user_submitted_data%' OR lastname LIKE '%user_submitted_data%'这在目前很有效,但是当用户提交全名时,(显然)不起作用.有没有办法在整个’WHERE类型条件’和’HAVING类型条件’之间添加OR?这样我可以做类似的事情:SELECT [some fiel...

mysql – 如何在没有where子句的情况下从两个不同的表中计算两列的总和?【代码】

我使用以下sql语句来汇总来自两个不同表的两列的值.该语句可以输出但不能输出所需的结果.SELECT SUM(`_income`.rate) AS Income, SUM(`_expense`.rate) AS Expense, SUM(_income.rate)-SUM(_expense.rate) AS Balance FROM `_expense`, `_income`我的桌子在这里:CREATE TABLE IF NOT EXISTS `_expense` (`id` int(11) NOT NULL AUTO_INCREMENT,`item` varchar(100) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL,`qnty` i...