hibernate uuid.hex主键生成+spring带来的困惑

原创 2006年06月15日 11:25:00
第二次插入就报错?


表结构

CREATE TABLE `cloumn` (
  `c_id` 
varchar(16)  NOT NULL,
  `u_id` 
varchar(16)  default NULL,
  `c_name` 
varchar(100default NULL,
  `c_sort` 
int(11default NULL,
  `c_beizhu` 
varchar(100) ,
  
PRIMARY KEY  (`c_id`)
 
)

2.配置文件
<?xml version="1.0" encoding='UTF-8'?>
<!DOCTYPE hibernate-mapping PUBLIC
                            "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
                            "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd" 
>

<hibernate-mapping>
<class
    
name="hibernate3test.dal.Cloumn"
    table
="cloumn"
>
    
<id name="cid" type="java.lang.String" column="c_id" >
//uuid.hex生成方式
        
<generator class="uuid.hex" />
    
</id>
    
<property name="u_id" type="java.lang.String" column="u_id" />
    
<property name="cname" type="java.lang.String" column="c_name" />
     
<property name="csort" type="java.lang.Integer" column="c_sort" />
      
<property name="cbeizhu" type="java.lang.String" column="c_beizhu" />

</class>
</hibernate-mapping>

spring配置文件
    <bean id="test" class="hibernate3test.dal.dal">
      
            
<property name="sessionFactory"><ref local="sessionFactory"/></property>   
    
</bean>


vo
public class Cloumn implements Serializable {

    
private String cid;
    
private String u_id;
    
private String cname;
    
private Integer csort;
    
private String cbeizhu;
    
public Cloumn() {
    }

//geter setter


dao 代码
package hibernate3test.dal;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;

public class dal extends HibernateDaoSupport {
    
public dal() {
    }

    
public void addCloumn()
    
{
        Cloumn cc 
= new Cloumn();
        cc.setU_id(
"297ebd930b46197a");
        cc.setCname(
"测试添加拦目1");
        cc.setCbeizhu(
"备注");
        cc.setCsort(
1);
        
this.getHibernateTemplate().save(cc);
    }


测试
    public static void main(String args[])
    
{
   
//加载spring配置文件
               Resource rs=new ClassPathResource("appcontext.xml");
        BeanFactory factory
=new XmlBeanFactory(rs);
//得到dal
        dal dao=(dal)factory.getBean("test");
//添加
       dao.addCloumn();
       
//第二次再次添加就报错..??
       
//dao.addCloumn();
    }



怎么会这样,第一次可以添加进数据库,第二次再调用dao.addCloumn()就报错?

这样做应该是没有问题的啊??
注:
我单独用hibernate测试没有问题,加上spring 问题就来了。。

以下是hibernate测试代码(通过)
//得到session
public Session getSession()
{
try
{
Configuration cfg = new Configuration().configure();
SessionFactory sf=cfg.buildSessionFactory();
return sf.openSession();
}
catch(Exception ee)
{
log.error("error:"+ee.getMessage());
}
return null;
}

//添加的方法
public void addCloumn()
{
Cloumn cc = new Cloumn();
cc.setU_id("297ebd930b46197a");
cc.setCname("测试添家拦目1");
cc.setCbeizhu("备注");
cc.setCsort(1);
Session ss=this.getSession();
ss.save(cc);
ss.flush();
ss.close();
}

public static void main(String[] args) {
dao test = new dao();
//添加
test.addCloumn();
再次添加
test.addCloumn();

}

这样没有问题。。

加了spring就有问题。
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Hibernate的uuid主键生成方式

hibernate uuid

使用UUID生成主键向Oracle中添加数据

用UUID生成主键,然后控制数据添加到Oracle中,具体代码如下/* *@(#)PrimaryKeyByUUID.java 2015年5月4日 * *Copyright 2015 Cbo,Al...

kettle生成主键UUID和调用转换作业

Kettle 已经归属Pentaho门下,4.1版本的下载地址:http://sourceforge.net/projects/pentaho/files/Data%20Integration/4.1...

Java密码加密,UUID自动生成主键

感谢这位博主 package com.sunnylocus.util;      import java.security.MessageDigest;      /**  ...

hibernate主键生成策略

  • 2011-12-12 10:14
  • 53KB
  • 下载

activiti uuid主键

activiti主键生成策略,activiti uuid主键,activiti分布式,activiti数据库主键,activiti id,activiti id自定义,activiti自定义id。分享...

hibernate主键生成策略

  • 2011-12-31 10:14
  • 22KB
  • 下载

MySQL 使用自增ID主键和UUID 作为主键的优劣比较详细过程(500W单表)

一个开发同事做了一个框架,里面主键是uuid,我跟他建议说MySQL不要用uuid用自增主键,自增主键效率高,他说不一定高,我说innodb的索引特性导致了自增id做主键是效率最好的,为了说服他,所以...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)