The databse returned no natively generated identity value问题

com.cqupt.dayday.model

代码

package com.cqupt.dayday.model;
import java.util.Date;

/**
 * Created by I am master on 2017/3/1.
 */

public class News {
    private Integer id;
    private String title;
    private String author;
    private Date date;

    public News(String title, String author, Date date) {
        this.title = title;
        this.author = author;
        this.date = date;
    }

    public News() {


    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getAuthor() {
        return author;
    }

    public void setAuthor(String author) {
        this.author = author;
    }

    public String getTitle() {
        return title;
    }

    public void setTitle(String title) {
        this.title = title;
    }

    public Date getDate() {
        return date;
    }

    public void setDate(Date date) {
        this.date = date;
    }

    @Override
    public String toString() {
        return "News{" +
                "id=" + id +
                ", title='" + title + '\'' +
                ", author='" + author + '\'' +
                ", date=" + date +
                '}';
    }
}

配置文件 News.hbm.xml

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate Mapping DTD 3.0"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
    <class name="com.cqupt.dayday.model.News" table="news">
        <id name="id" type="java.lang.Integer">
            <column name="id"/>
            <!--指定主键的生成方式, native:使用数据库本地方式-->
            <generator class="native"/>
        </id>
        <property name="title" type="java.lang.String">
            <column name="title"/>
        </property>
        <property name="author" type="java.lang.String">
            <column name="author"/>
        </property>
        <property name="date" type="java.util.Date">
            <column name="date"/>
        </property>
    </class>
</hibernate-mapping>

hibernate.cfg.xml

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate Mapping DTD 3.0"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
    <class name="com.cqupt.dayday.model.News" table="news">
        <id name="id" type="java.lang.Integer">
            <column name="id"/>
            <!--指定主键的生成方式, native:使用数据库本地方式-->
            <generator class="native"/>
        </id>
        <property name="title" type="java.lang.String">
            <column name="title"/>
        </property>
        <property name="author" type="java.lang.String">
            <column name="author"/>
        </property>
        <property name="date" type="java.util.Date">
            <column name="date"/>
        </property>
    </class>
</hibernate-mapping>

 

com.cqupt.dayday

测试类

package com.cqupt.dayday;

import com.cqupt.dayday.model.News;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;
import org.junit.Test;

import java.util.Date;

/**
 * Created by I am master on 2017/3/1.
 */
public class HibernateTest {
    @Test
    public void test()  {

        SessionFactory sessionFactory=null;

        Configuration configuration=new Configuration().configure();
          //最老的jar包需要这样写,用最新的jar包写会报错
//        ServiceRegistry serviceRegistry=new StandardServiceRegistryBuilder()
//                .applySettings(configuration.getProperties()).build();

        sessionFactory=configuration.buildSessionFactory();

        Session session=sessionFactory.openSession();

        Transaction transaction=session.beginTransaction();

        News news=new News();
        news.setAuthor("dayday");
        news.setDate(new Date());
        news.setTitle("java");

        System.out.println(news);
        System.out.println("-----"+session);

        session.save(news);

        transaction.commit();

        session.close();

        sessionFactory.close();
    }

}

遇到的问题

 

1)The databse returned no natively generated identity value

2)使用老式jar包

出错原因:

在指定主键生成策略的时候、配置了<generator class="native"/> 、这是提供自动增长、为数据表中的主键自动增长、但是如果数据库没有定义id列为自动增长的话、就会出现The database returned no natively generated identity value错误

解决方法:

在数据库中手动定义id列自动增长或在数据库中不手动建立该张数据表

posted @ 2017-03-01 17:11  何甜甜在吗  阅读(493)  评论(0编辑  收藏  举报