phpmyadmin Mysql查询多个表和内部连接

wlwcrazw  于 2024-01-09  发布在  PHP
关注(0)|答案(2)|浏览(266)

我有3个表,我想有一个查询,给我的销售额,存款和它们之间的差异的总和,尝试这个,但记录重复。
这是我的疑问:

  1. -- phpMyAdmin SQL Dump
  2. -- version 4.9.11
  3. -- https://www.phpmyadmin.net/
  4. --
  5. -- Servidor: localhost:3306
  6. -- Tiempo de generación: 28-11-2023 a las 16:25:38
  7. -- Versión del servidor: 5.6.41-84.1
  8. -- Versión de PHP: 7.4.33
  9. SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO";
  10. SET AUTOCOMMIT = 0;
  11. START TRANSACTION;
  12. SET time_zone = "+00:00";
  13. /*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
  14. /*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
  15. /*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
  16. /*!40101 SET NAMES utf8mb4 */;
  17. --
  18. -- Base de datos: `geasacpe_consolidado`
  19. --
  20. -- --------------------------------------------------------
  21. --
  22. -- Estructura de tabla para la tabla `articulo`
  23. --
  24. CREATE TABLE `articulo` (
  25. `id_articulo` int(11) NOT NULL,
  26. `nombre_articulo` varchar(50) COLLATE utf8_unicode_ci NOT NULL,
  27. `precio` decimal(10,2) NOT NULL,
  28. `id_local` int(11) NOT NULL
  29. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
  30. --
  31. -- Volcado de datos para la tabla `articulo`
  32. --
  33. INSERT INTO `articulo` (`id_articulo`, `nombre_articulo`, `precio`, `id_local`) VALUES
  34. (1, 'PREMIUN AVENTURERO', '10.00', 1),
  35. (2, 'REGULAR AVENTURERO', '8.00', 1),
  36. (3, 'GLP AVENTURERO', '5.00', 1),
  37. (4, 'PREMIUN EL FIEL', '12.00', 2),
  38. (5, 'REGULAR EL FIEL', '9.00', 2),
  39. (6, 'GLP EL FIEL', '4.00', 2);
  40. -- --------------------------------------------------------
  41. --
  42. -- Estructura de tabla para la tabla `contometro`
  43. --
  44. CREATE TABLE `contometro` (
  45. `id_contometro` int(11) NOT NULL,
  46. `fecha_contometro` date NOT NULL,
  47. `turno_contometro` int(11) NOT NULL,
  48. `inicial_contometro` int(11) NOT NULL,
  49. `final_contometro` int(11) NOT NULL,
  50. `precio_articulo` decimal(10,3) NOT NULL,
  51. `id_local` int(11) NOT NULL,
  52. `id_manguera` int(11) NOT NULL,
  53. `id_punto` int(11) NOT NULL,
  54. `id_lado` int(11) NOT NULL,
  55. `id_articulo` int(11) NOT NULL,
  56. `id_vendedor` int(11) NOT NULL
  57. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
  58. --
  59. -- Volcado de datos para la tabla `contometro`
  60. --
  61. INSERT INTO `contometro` (`id_contometro`, `fecha_contometro`, `turno_contometro`, `inicial_contometro`, `final_contometro`, `precio_articulo`, `id_local`, `id_manguera`, `id_punto`, `id_lado`, `id_articulo`, `id_vendedor`) VALUES
  62. (3, '2023-11-28', 1, 0, 10, '10.000', 1, 1, 1, 1, 1, 1),
  63. (4, '2023-11-28', 1, 0, 8, '8.000', 1, 2, 1, 1, 2, 1),
  64. (5, '2023-11-28', 1, 0, 12, '5.000', 1, 3, 1, 1, 3, 1),
  65. (6, '2023-11-28', 1, 0, 13, '10.000', 1, 4, 1, 2, 1, 1);
  66. -- --------------------------------------------------------
  67. --
  68. -- Estructura de tabla para la tabla `depositoxvendedor`
  69. --
  70. CREATE TABLE `depositoxvendedor` (
  71. `id_depositoxvendedor` int(11) NOT NULL,
  72. `fecha_depositoxvendedor` date NOT NULL,
  73. `turno_depositoxvendedor` int(11) NOT NULL,
  74. `numero_depositoxvendedor` int(11) NOT NULL,
  75. `monto_depositoxvendedor` decimal(10,2) NOT NULL,
  76. `id_tipopago` int(11) NOT NULL,
  77. `id_vendedor` int(11) NOT NULL,
  78. `id_local` int(11) NOT NULL
  79. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
  80. --
  81. -- Volcado de datos para la tabla `depositoxvendedor`
  82. --
  83. INSERT INTO `depositoxvendedor` (`id_depositoxvendedor`, `fecha_depositoxvendedor`, `turno_depositoxvendedor`, `numero_depositoxvendedor`, `monto_depositoxvendedor`, `id_tipopago`, `id_vendedor`, `id_local`) VALUES
  84. (1, '2023-11-28', 1, 1, '100.00', 1, 1, 1),
  85. (2, '2023-11-28', 1, 2, '150.00', 2, 1, 1),
  86. (3, '2023-11-28', 1, 3, '50.00', 1, 2, 1),
  87. (4, '2023-11-28', 1, 4, '30.00', 2, 2, 1);
  88. -- --------------------------------------------------------
  89. --
  90. -- Estructura de tabla para la tabla `lado`
  91. --
  92. CREATE TABLE `lado` (
  93. `id_lado` int(11) NOT NULL,
  94. `numero_lado` int(11) NOT NULL,
  95. `id_punto` int(11) NOT NULL,
  96. `id_local` int(11) NOT NULL
  97. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
  98. --
  99. -- Volcado de datos para la tabla `lado`
  100. --
  101. INSERT INTO `lado` (`id_lado`, `numero_lado`, `id_punto`, `id_local`) VALUES
  102. (1, 1, 1, 1),
  103. (2, 2, 1, 1),
  104. (3, 3, 3, 1),
  105. (4, 4, 3, 1),
  106. (5, 1, 4, 2),
  107. (6, 2, 4, 2),
  108. (7, 3, 2, 2),
  109. (8, 4, 2, 2);
  110. -- --------------------------------------------------------
  111. --
  112. -- Estructura de tabla para la tabla `local`
  113. --
  114. CREATE TABLE `local` (
  115. `id_local` int(11) NOT NULL,
  116. `nombre_local` varchar(50) COLLATE utf8_unicode_ci NOT NULL
  117. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
  118. --
  119. -- Volcado de datos para la tabla `local`
  120. --
  121. INSERT INTO `local` (`id_local`, `nombre_local`) VALUES
  122. (1, 'AVENTURERO'),
  123. (2, 'EL FIEL INCOMPRENDIDO');
  124. -- --------------------------------------------------------
  125. --
  126. -- Estructura de tabla para la tabla `manguera`
  127. --
  128. CREATE TABLE `manguera` (
  129. `id_manguera` int(11) NOT NULL,
  130. `numero_manguera` int(11) NOT NULL,
  131. `id_lado` int(11) NOT NULL,
  132. `id_articulo` int(11) NOT NULL,
  133. `id_local` int(11) NOT NULL
  134. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
  135. --
  136. -- Volcado de datos para la tabla `manguera`
  137. --
  138. INSERT INTO `manguera` (`id_manguera`, `numero_manguera`, `id_lado`, `id_articulo`, `id_local`) VALUES
  139. (1, 1, 1, 1, 1),
  140. (2, 2, 1, 2, 1),
  141. (3, 3, 1, 3, 1),
  142. (4, 1, 2, 1, 1),
  143. (5, 2, 2, 2, 1),
  144. (6, 3, 2, 3, 1);
  145. -- --------------------------------------------------------
  146. --
  147. -- Estructura de tabla para la tabla `punto`
  148. --
  149. CREATE TABLE `punto` (
  150. `id_punto` int(11) NOT NULL,
  151. `marca_punto` varchar(50) COLLATE utf8_unicode_ci DEFAULT NULL,
  152. `modelo_punto` varchar(50) COLLATE utf8_unicode_ci DEFAULT NULL,
  153. `id_local` int(11) NOT NULL
  154. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
  155. --
  156. -- Volcado de datos para la tabla `punto`
  157. --
  158. INSERT INTO `punto` (`id_punto`, `marca_punto`, `modelo_punto`, `id_local`) VALUES
  159. (1, 'GILBARCO AVENTURERO', '3000', 1),
  160. (2, 'TOKEIN EL FIEL', '2000', 2),
  161. (3, 'TOKEIN AVENTURERO', '2000', 1),
  162. (4, 'GILBARCO EL FIEL', '3000', 2);
  163. -- --------------------------------------------------------
  164. --
  165. -- Estructura de tabla para la tabla `puntoxvendedor`
  166. --
  167. CREATE TABLE `puntoxvendedor` (
  168. `id_puntoxvendedor` int(11) NOT NULL,
  169. `fecha_puntoxvendedor` date NOT NULL,
  170. `turno_puntoxvendedor` int(11) NOT NULL,
  171. `id_punto` int(11) NOT NULL,
  172. `id_vendedor` int(11) NOT NULL
  173. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
  174. --
  175. -- Volcado de datos para la tabla `puntoxvendedor`
  176. --
  177. INSERT INTO `puntoxvendedor` (`id_puntoxvendedor`, `fecha_puntoxvendedor`, `turno_puntoxvendedor`, `id_punto`, `id_vendedor`) VALUES
  178. (1, '2023-11-28', 1, 1, 1),
  179. (2, '2023-11-28', 1, 3, 2);
  180. -- --------------------------------------------------------
  181. --
  182. -- Estructura de tabla para la tabla `vendedor`
  183. --
  184. CREATE TABLE `vendedor` (
  185. `id_vendedor` int(11) NOT NULL,
  186. `nombre_vendedor` varchar(50) COLLATE utf8_unicode_ci NOT NULL,
  187. `id_local` int(11) NOT NULL
  188. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
  189. --
  190. -- Volcado de datos para la tabla `vendedor`
  191. --
  192. INSERT INTO `vendedor` (`id_vendedor`, `nombre_vendedor`, `id_local`) VALUES
  193. (1, 'VENDEDOR 1 AVENTURERO', 1),
  194. (2, 'VENDEDOR 2 AVENTURERO', 1),
  195. (3, 'VENDEDOR 1 EL FIEL', 2),
  196. (4, 'VENDEDOR 2 EL FIEL', 2);
  197. --
  198. -- Índices para tablas volcadas
  199. --
  200. --
  201. -- Indices de la tabla `articulo`
  202. --
  203. ALTER TABLE `articulo`
  204. ADD PRIMARY KEY (`id_articulo`),
  205. ADD KEY `id_local` (`id_local`);
  206. --
  207. -- Indices de la tabla `contometro`
  208. --
  209. ALTER TABLE `contometro`
  210. ADD PRIMARY KEY (`id_contometro`),
  211. ADD KEY `id_local` (`id_local`),
  212. ADD KEY `id_manguera` (`id_manguera`),
  213. ADD KEY `id_punto` (`id_punto`),
  214. ADD KEY `id_lado` (`id_lado`),
  215. ADD KEY `id_articulo` (`id_articulo`),
  216. ADD KEY `id_vendedor` (`id_vendedor`);
  217. --
  218. -- Indices de la tabla `depositoxvendedor`
  219. --
  220. ALTER TABLE `depositoxvendedor`
  221. ADD PRIMARY KEY (`id_depositoxvendedor`),
  222. ADD KEY `id_vendedor` (`id_vendedor`),
  223. ADD KEY `id_local` (`id_local`);
  224. --
  225. -- Indices de la tabla `lado`
  226. --
  227. ALTER TABLE `lado`
  228. ADD PRIMARY KEY (`id_lado`),
  229. ADD KEY `id_punto` (`id_punto`),
  230. ADD KEY `id_local` (`id_local`);
  231. --
  232. -- Indices de la tabla `local`
  233. --
  234. ALTER TABLE `local`
  235. ADD PRIMARY KEY (`id_local`);
  236. --
  237. -- Indices de la tabla `manguera`
  238. --
  239. ALTER TABLE `manguera`
  240. ADD PRIMARY KEY (`id_manguera`),
  241. ADD KEY `id_lado` (`id_lado`),
  242. ADD KEY `id_articulo` (`id_articulo`),
  243. ADD KEY `id_local` (`id_local`);
  244. --
  245. -- Indices de la tabla `punto`
  246. --
  247. ALTER TABLE `punto`
  248. ADD PRIMARY KEY (`id_punto`),
  249. ADD KEY `id_local` (`id_local`);
  250. --
  251. -- Indices de la tabla `puntoxvendedor`
  252. --
  253. ALTER TABLE `puntoxvendedor`
  254. ADD PRIMARY KEY (`id_puntoxvendedor`),
  255. ADD KEY `id_punto` (`id_punto`),
  256. ADD KEY `id_vendedor` (`id_vendedor`);
  257. --
  258. -- Indices de la tabla `vendedor`
  259. --
  260. ALTER TABLE `vendedor`
  261. ADD PRIMARY KEY (`id_vendedor`),
  262. ADD KEY `id_local` (`id_local`);
  263. --
  264. -- AUTO_INCREMENT de las tablas volcadas
  265. --
  266. --
  267. -- AUTO_INCREMENT de la tabla `articulo`
  268. --
  269. ALTER TABLE `articulo`
  270. MODIFY `id_articulo` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=7;
  271. --
  272. -- AUTO_INCREMENT de la tabla `contometro`
  273. --
  274. ALTER TABLE `contometro`
  275. MODIFY `id_contometro` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=7;
  276. --
  277. -- AUTO_INCREMENT de la tabla `depositoxvendedor`
  278. --
  279. ALTER TABLE `depositoxvendedor`
  280. MODIFY `id_depositoxvendedor` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=5;
  281. --
  282. -- AUTO_INCREMENT de la tabla `lado`
  283. --
  284. ALTER TABLE `lado`
  285. MODIFY `id_lado` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=9;
  286. --
  287. -- AUTO_INCREMENT de la tabla `local`
  288. --
  289. ALTER TABLE `local`
  290. MODIFY `id_local` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=3;
  291. --
  292. -- AUTO_INCREMENT de la tabla `manguera`
  293. --
  294. ALTER TABLE `manguera`
  295. MODIFY `id_manguera` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=7;
  296. --
  297. -- AUTO_INCREMENT de la tabla `punto`
  298. --
  299. ALTER TABLE `punto`
  300. MODIFY `id_punto` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=5;
  301. --
  302. -- AUTO_INCREMENT de la tabla `puntoxvendedor`
  303. --
  304. ALTER TABLE `puntoxvendedor`
  305. MODIFY `id_puntoxvendedor` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=3;
  306. --
  307. -- AUTO_INCREMENT de la tabla `vendedor`
  308. --
  309. ALTER TABLE `vendedor`
  310. MODIFY `id_vendedor` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=5;
  311. --
  312. -- Restricciones para tablas volcadas
  313. --
  314. --
  315. -- Filtros para la tabla `articulo`
  316. --
  317. ALTER TABLE `articulo`
  318. ADD CONSTRAINT `articulo_ibfk_1` FOREIGN KEY (`id_local`) REFERENCES `local` (`id_local`);
  319. --
  320. -- Filtros para la tabla `contometro`
  321. --
  322. ALTER TABLE `contometro`
  323. ADD CONSTRAINT `contometro_ibfk_1` FOREIGN KEY (`id_local`) REFERENCES `local` (`id_local`),
  324. ADD CONSTRAINT `contometro_ibfk_2` FOREIGN KEY (`id_manguera`) REFERENCES `manguera` (`id_manguera`),
  325. ADD CONSTRAINT `contometro_ibfk_3` FOREIGN KEY (`id_punto`) REFERENCES `punto` (`id_punto`),
  326. ADD CONSTRAINT `contometro_ibfk_4` FOREIGN KEY (`id_lado`) REFERENCES `lado` (`id_lado`),
  327. ADD CONSTRAINT `contometro_ibfk_5` FOREIGN KEY (`id_articulo`) REFERENCES `articulo` (`id_articulo`),
  328. ADD CONSTRAINT `contometro_ibfk_6` FOREIGN KEY (`id_vendedor`) REFERENCES `vendedor` (`id_vendedor`);
  329. --
  330. -- Filtros para la tabla `depositoxvendedor`
  331. --
  332. ALTER TABLE `depositoxvendedor`
  333. ADD CONSTRAINT `depositoxvendedor_ibfk_1` FOREIGN KEY (`id_vendedor`) REFERENCES `vendedor` (`id_vendedor`),
  334. ADD CONSTRAINT `depositoxvendedor_ibfk_2` FOREIGN KEY (`id_local`) REFERENCES `local` (`id_local`);
  335. --
  336. -- Filtros para la tabla `lado`
  337. --
  338. ALTER TABLE `lado`
  339. ADD CONSTRAINT `lado_ibfk_1` FOREIGN KEY (`id_punto`) REFERENCES `punto` (`id_punto`),
  340. ADD CONSTRAINT `lado_ibfk_2` FOREIGN KEY (`id_local`) REFERENCES `local` (`id_local`);
  341. --
  342. -- Filtros para la tabla `manguera`
  343. --
  344. ALTER TABLE `manguera`
  345. ADD CONSTRAINT `manguera_ibfk_1` FOREIGN KEY (`id_lado`) REFERENCES `lado` (`id_lado`),
  346. ADD CONSTRAINT `manguera_ibfk_2` FOREIGN KEY (`id_articulo`) REFERENCES `articulo` (`id_articulo`),
  347. ADD CONSTRAINT `manguera_ibfk_3` FOREIGN KEY (`id_local`) REFERENCES `local` (`id_local`);
  348. --
  349. -- Filtros para la tabla `punto`
  350. --
  351. ALTER TABLE `punto`
  352. ADD CONSTRAINT `punto_ibfk_1` FOREIGN KEY (`id_local`) REFERENCES `local` (`id_local`);
  353. --
  354. -- Filtros para la tabla `puntoxvendedor`
  355. --
  356. ALTER TABLE `puntoxvendedor`
  357. ADD CONSTRAINT `puntoxvendedor_ibfk_1` FOREIGN KEY (`id_punto`) REFERENCES `punto` (`id_punto`),
  358. ADD CONSTRAINT `puntoxvendedor_ibfk_2` FOREIGN KEY (`id_vendedor`) REFERENCES `vendedor` (`id_vendedor`);
  359. --
  360. -- Filtros para la tabla `vendedor`
  361. --
  362. ALTER TABLE `vendedor`
  363. ADD CONSTRAINT `vendedor_ibfk_1` FOREIGN KEY (`id_local`) REFERENCES `local` (`id_local`);
  364. COMMIT;
  365. /*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
  366. /*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
  367. /*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;

个字符
The query gives me this result
结果应该是:
| 日期|图尔诺|文代多尔|Deposito|轮廓测量|
| --|--|--|--|--|
| 2023年11月28日| 1 |供应商1 AVENTURERO|二百五十|354.00|

rmbxnbpk

rmbxnbpk1#

试试这个:

  1. select DV.fecha_depositoxvendedor as date, turno, V.nombre_vendedor as vendedor,
  2. sum(DV.monto_depositoxvendedor) as deposito,
  3. any_value(C.contometria) as contometria -- The aggregation function any_value makes the syntax right but logically uncenessary, as the aggregation is already done in the derived table C. Use min or max if function any_value is not available.
  4. from
  5. (select id_vendedor , turno_contometro as turno, sum((final_contometro-inicial_contometro)*precio_articulo) as contometria
  6. from contometro
  7. group by id_vendedor, turno) C
  8. inner join vendedor V on C.id_vendedor=V.id_vendedor
  9. inner join depositoxvendedor DV on DV.id_vendedor=V.id_vendedor
  10. group by vendedor, date, turno
  11. ;
  12. -- result
  13. +------------+-------+-----------------------+----------+-------------+
  14. | date | turno | vendedor | deposito | contometria |
  15. +------------+-------+-----------------------+----------+-------------+
  16. | 2023-11-28 | 1 | VENDEDOR 1 AVENTURERO | 250.00 | 354.000 |
  17. +------------+-------+-----------------------+----------+-------------+

字符串
请注意,答案是使用指定的SQL_MODE值ONLY_FULL_GROUP_BY编写的,该值不允许选择列表具有 * 非聚合列,这些列既不在GROUP BY子句中命名,也在功能上不依赖于(唯一确定的)GROUP BY列 *。当我们在SQL_MODE中有值时,如果我们在主查询结束时从group by列表中删除turno,则发生错误。

  1. select DV.fecha_depositoxvendedor as date, turno, V.nombre_vendedor as vendedor,
  2. sum(DV.monto_depositoxvendedor) as deposito,
  3. any_value(C.contometria) as contometria -- The aggregation function any_value makes the syntax right but logically uncenessary, as the aggregation is already done in the derived table C.
  4. from
  5. (select id_vendedor , turno_contometro as turno, sum((final_contometro-inicial_contometro)*precio_articulo) as contometria
  6. from contometro
  7. group by id_vendedor, turno) C
  8. inner join vendedor V on C.id_vendedor=V.id_vendedor
  9. inner join depositoxvendedor DV on DV.id_vendedor=V.id_vendedor
  10. group by vendedor, date
  11. ;
  12. -- result:
  13. ERROR 1055 (42000): Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'C.turno' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by


如果我们删除ONLY_FULL_GROUP_BY,它将不会失败。
最后,这可能超出了我对业务逻辑的关注,但我认为仅使用id_vendedor的连接条件不太令人满意。我们是否应该考虑进一步的连接条件,例如在表contometrodepositoxvendedor之间匹配日期和turno?

展开查看全部
b1payxdu

b1payxdu2#

问题是所有的JOINing都发生在任何聚合之前)sic为SUM())。这可能会得到正确的总和。(注意,它消除了对GROUP BY的需要。)

  1. SELECT V.nombre_vendedor as vendedor,
  2. ( SELECT sum(DV.monto_depositoxvendedor)
  3. FROM depositoxvendedor DV
  4. WHERE DV.id_vendedor=V.id_vendedor ) as deposito,
  5. ( SELECT sum((C.final_contometro - C.inicial_contometro) * C.precio_articulo)
  6. ) as contometria
  7. FROM vendedor V

字符串
我不知道如何处理C.fecha_contometroC.turno_contometro,因为每个供应商都有多个fecha,等等。

相关问题