表結構
`c_id` varchar(16) NOT NULL,
`u_id` varchar(16) default NULL,
`c_name` varchar(100) default NULL,
`c_sort` int(11) default NULL,
`c_beizhu` varchar(100) ,
PRIMARY KEY (`c_id`)
)
2.配置文件
<!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配置文件
<property name="sessionFactory"><ref local="sessionFactory"/></property>
</bean>
vo
private String cid;
private String u_id;
private String cname;
private Integer csort;
private String cbeizhu;
public Cloumn() {
}
//geter setter
dao 代碼
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);
}
測試
{
//加載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測試代碼(通過)
//得到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就有問題。