Heim >Backend-Entwicklung >PHP-Tutorial >一个mysql查询的问题,在线等马上就能结贴

一个mysql查询的问题,在线等马上就能结贴

WBOY
WBOYOriginal
2016-06-23 14:19:14983Durchsuche

mysql 表设计 查询

脑子糊涂了绕不过来这个弯  求助

我有两个表,t1表存储数据,t2表存储t1表字段的中文名称

t1



t2表



现在想写一条sql语句,能够查出t1表里 id in (1,2,3,4,5)的这几条记录每一个字段值的和,并且把字段名替换成t2表里对应的中文字段名,

结果类似于
array(
   "攻击时附加" =>  6,
   "暴击效果" => 7,
   ....
)

语句应该怎么写?   本来感觉应该不难的怎么就突然想不出来了   脖子都快抽筋了

是不是表设计的有问题? 有没有更好的方式

回复讨论(解决方案)

看不出结果数组与表中数据有什么对应关系

抱歉 结果数组我随手写的  没有准确计算数值 

我重新写一下

array(
    "攻击时附加$n点伤害"=>24,
    "生命值恢复增加每秒$n点"=>48,
    "暴击伤害增加$n"=>27,
    "装备等级减少$n"=>6,
    "金币掉落增加$n"=>100
)

当然,如果能查出
array(
   0=> "攻击时附加24点伤害",
   0=> "生命值恢复增加每秒48点",
   0=> "暴击伤害增加27",
   0=> "装备等级减少6",
   0=> "金币掉落增加100"
)
不过貌似不太可能... 这样的设计或许有问题    

array(
   0=> "攻击时附加24点伤害",
   1=> "生命值恢复增加每秒48点",
   2=> "暴击伤害增加27",
   3=> "装备等级减少6",
   4=> "金币掉落增加100"
)

上边写的都是0是有误的..

  48应为43..... 瀑布汗..

select sum(col1),sum(col2),sum(col3),sum(col4),sum(col5) from t1 where id in(1,2,3,4,5);

这样可以查询出五个col字段之和,不过你后面的更新没有规律,似乎只能写死的了。

select sum(col1),sum(col2),sum(col3),sum(col4),sum(col5) from t1 where id in(1,2,3,4,5);

这样可以查询出五个col字段之和,不过你后面的更新没有规律,似乎只能写死的了。

这个不失为一个办法,虽然col x的数量可能有几十个但是毕竟变化不多

但是没有语句可以直接"查出每一项的合"吗?

那个语句就是查询出每一项的和啊

感觉是你表设计有问题。这个是一个m2m关系,一般设计3个表。
我将你的大概理解为游戏中的武器附加属性:
表a:武器表
id name
 1  A
表b:属性表
id desc
 1 攻击附加n
 2 生命值恢复n

表c:武器属性映射表
id  a_id  b_id n
1    1     1   24
2    1     2   30

表c的数据就说明了武器A攻击附加24,生命值恢复30

个人拙见!不喜勿喷!

感觉是你表设计有问题。这个是一个m2m关系,一般设计3个表。
我将你的大概理解为游戏中的武器附加属性:
表a:武器表
id name
 1  A
表b:属性表
id desc
 1 攻击附加n
 2 生命值恢复n

表c:武器属性映射表
id  a_id  b_id n
1    1     1   24
2    1     2   30

表c的数据就说明了武器A攻击附加24,生命值恢复30

个人拙见!不喜勿喷!

是游戏中的属性没错   你这个提法不错, 我把每件装备的属性做到一条记录里,可能是为了更直观?我也说不清楚...  我考虑下吧三个表的形式...

那个语句就是查询出每一项的和啊

这个方法不是说不行 但是如果有100个字段还要这么写感觉也不是很合适....之前我以为有一条命令什么的可以直接自动查找所有字段的和.

你的结果是“交叉表”
你需要从 t2 中组装查询指令
可以用存储过程,也可以用php

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn