Hibernate使用UUID和MAP映射的问题

先看代码

        <id name="id">
            <generator class="uuid" />
        </id>
               
    	<discriminator column="p_type" type="string"/>
    	
    	<property name="name" length="20"/>
    	
    	<map name="map" table="t_map" cascade="all">
    		<key column="id"/>
    		<map-key type="string" column="p_name" ></map-key>
    		<element type="big_decimal" column="p_value"></element>
    	</map>
 

在如上的映射中,我用hibernate的SchemaExport工具导出表,试了好多次,map映射的表t_map都没有生成,百思不得起解,后来把DDL语句在mysql中手动建表,发现mysql报了如下错误:

 

Specified key was too long; max key length is 1000 bytes

 

原来是t_map用的联合主建,而hibernate如果是String类型,又没有指定长度,默认是255,主键太长了,导致建表不成功,后来在id字段和map映射的map-key上加了长度限制,建表成功。

        <id name="id" length="32">
            <generator class="uuid" />
        </id>
               
    	<discriminator column="p_type" type="string"/>
    	
    	<property name="name" length="20"/>
    	
    	<map name="map" table="t_map" cascade="all">
    		<key column="id"/>
    		<map-key type="string" column="p_name" length="50"></map-key>
    		<element type="big_decimal" column="p_value"></element>
    	</map>
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值