• 06-编写Hibernate API编写访问数据库的代码,使用Junit进行测试


    用到的注解:

    @Test:测试方法

    @Before:初始化方法。

    @After:是否资源

    先执行Befere,然后执行Test,最后执行After

    第一步:新建一个Junit目录。

    第二步:取名

    该目录下新建一个类:

    代码如下:

    import org.junit.After;
    import org.junit.Before;
    import org.junit.Test;
    
    //测试类
    public class StudentsTest {
        
        @Before
        public void init()
        {
            
        }
        @After
        public void destory()
        {
            
        }
        
        @Test
        public void testSaveStudents()
        {
            
        }
    
    }

    通过hibernate API编写访问数据库的代码

    Before初始化需要执行以下操作:

    Configuration config=new Configuration().configure();//创建配置对象

    ServiceRegistry serviceRegistry=new ServiceRegistryBuilder().

    applySettions(config.getProperties() ).buildServiceRegistry();//创建服务注册对象。

    sessionFactory=config.buildSessionFactory(serviceRegistry);//创建会话工厂对象。

    session=sessionFactory.openSession();//打开会话

    transaction=session.beginTransaction();//打开事务

    在Test类里面如下写:

    import java.util.Date;
    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.After;
    import org.junit.Before;
    import org.junit.Test;
    
    //测试类
    public class StudentsTest {
        
        private SessionFactory sessionFactory;
        private Session session;
        private Transaction transaction;
        @Before
        public void init()
        {
            //创建配置对象
            Configuration config=new Configuration().configure();
            config.addClass(Students.class);//这个需要加上(视频里面没有)
            //创建服务注册对象。
            ServiceRegistry serviceRegistry=new StandardServiceRegistryBuilder()
                    .applySettings(config.getProperties()).build(); //通过config.getProperties()读取配置文档。
            //创建会话工厂对象
            sessionFactory=config.buildSessionFactory(serviceRegistry);
            //创建会话对象
            session=sessionFactory.openSession();
            //开启事务
            transaction=session.beginTransaction();
        }
        @After
        public void destory()
        {
            transaction.commit();//提交事务
            session.close();//关闭会话
            sessionFactory.close();//关闭会话工厂
        }
        
        @Test
        public void testSaveStudents()
        {
            //生成学生对象
            Students s=new Students(1,"张三丰","男",new Date(),"武当山");
            session.save(s);//保存对象进入数据库
        }
    
    }

    在里面,通过session对象自带的save执行保存方法。

     之前调试的时候一堆错误,最后发现主要是以下问题:

    1,缺少这句话,后期加上了:config.addClass(Students.class);/

    2,hbm.xml文件默认不在src下,手动加到下面,与cfg.xml一个目录,否则: <mapping resource="Students.hbm.xml"/>就需要加入包名。

    3,数据库配置重新弄了一下:

    <property name="connection.url">jdbc:mysql://localhost:3306/sys</property>

  • 相关阅读:
    error C4430: 缺少类型说明符
    Fiddler 教程
    make: Nothing to be done for 'first'
    Qt Creator + MinGW 在windows 下的调试GDB停止工作解决
    WIN7成功安装Qt4.8方法,无需VS支持
    深入研究 UCenter API For .NET
    C#在Winform程序中显示QQ在线状态
    VS2010 需要缺少的web组件才能加载该项目
    System.Runtime.InteropServices.COMException: 检索 COM 类工厂中 CLSID 为 {0002E510-0000-0000-C000-000000000046} 的组件时失败,原因是出现以下错误: 80040154
    c#while循环注意continue的地方
  • 原文地址:https://www.cnblogs.com/alsf/p/7819864.html
Copyright © 2020-2023  润新知