热搜:NVER node 开发 php

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

2024-09-21 13:40:01
一个mysql查询的问题,在线等马上就能结贴

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