运行Java代码后从数据库中删除记录

时间:2018-07-23 19:37:26

标签: java mysql hibernate

我已经通过休眠和实体将MySQL数据库连接到Java Spring MVC代码。

我已将记录添加到MySQL的Clients表中,并成功地从Intelij中获取了记录。

但是,在运行以下代码之后,所有记录都已从我的数据库中删除。

package com.example.WebAppProcess20.Entities;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

import java.util.ArrayList;

public class dbCheck {
    public static void main (String [] args) throws Exception{
        Configuration cfg = new Configuration();
        cfg.configure("hibernate.cfg.xml");
        SessionFactory factory = cfg.buildSessionFactory();
        Session session = factory.openSession();

        ArrayList<ClientsEntity> li = (ArrayList<ClientsEntity>)session.createQuery("from ClientsEntity").list();
        for (ClientsEntity c: li) {
            System.out.println(c.getClientName());
        }
        session.close();
        factory.close();
    }
}

你能解释为什么吗?

谢谢

1 个答案:

答案 0 :(得分:1)

您的ddl中的hibernate.cfg.xml设置可能设置为在每次运行应用程序时重新创建架构,通过该架构,每次运行时将擦除所有数据。检查this链接(感谢@notyou)以了解如何修改它以便保留以前的数据。