小编Mic*_*ael的帖子

在MySQL中实现ac/c ++样式union作为列

朋友们,

我有一个奇怪的需要,无法思考我的问题.由于关键字回收,优秀而强大的Google几乎没有帮助(正如您所见).你能帮我吗?

我想要做的是将多种类型的数据存储在MySQL的单个列中.

这是一个等同于C联合的数据库(如果你搜索MySQL和Union,你显然在SQL中的UNION关键字上得到了很多东西).

[随后简化案例]因此,让我们说我们有人 - 有名字 - 和STORMTROOPERS - 有TK号码.您不能同时拥有名称和TK编号.你要么是BOB SMITH - 或者 - TK409.

在CI中可以将其表达为联盟,如下所示:

union {
        char * name;
        int tkNo;
      } EmperialPersonnelRecord;
Run Code Online (Sandbox Code Playgroud)

这使得它,这样我要么存储一个指向字符数组在类型EmperialPersonnelRecord的ID,但不是两者.

我在列上寻找MySQL等价物.我的列将存储int,double或varchar(255)(或任何组合).但只占用最大元素的空间.

这可能吗?

(当然,只要有足够的时间,金钱和意志,任何事情都是可能的 - 我的意思是,如果我是穷人,懒惰并且在截止日期之前有可能......也就是"开箱即用")

c mysql unions

6
推荐指数
1
解决办法
508
查看次数

标签 统计

c ×1

mysql ×1

unions ×1