三大框架:
一般使用的是SpringMVC+Spring+hibernate,因为Struts的bug太多,功能较少;Struts2学习成本较高
注意需要在联网的情况下搭建,因为idea需要联网去网络上下载项目需要的资源,但如果在maven仓库中已经下载好了资源,则可以不用联网
UTF-8
1.8
1.8
org.springframework
spring-web
4.2.5.RELEASE
org.springframework
spring-webmvc
4.2.5.RELEASE
org.springframework
spring-jdbc
4.2.5.RELEASE
org.springframework
spring-orm
4.2.5.RELEASE
org.hibernate
hibernate-core
4.3.8.Final
org.hibernate
hibernate-entitymanager
4.3.8.Final
mysql
mysql-connector-java
5.1.6
commons-dbcp
commons-dbcp
1.2.2
org.springframework
spring-test
4.2.5.RELEASE
org.aspectj
aspectjweaver
1.8.9
com.fasterxml.jackson.core
jackson-databind
2.6.5
junit
junit
4.12
test
下面我们就正式的集成SSJ框架
jdbc.driverClassName=com.mysql.jdbc.Driver /*jdbc.driverClassName这个可以自定义*/
jdbc.url=jdbc:mysql:///ssj /*配置自定义的数据库*/
jdbc.username=root
jdbc.password=admin
alt+insert快键,可以快速弹出gernerate窗口,选择JPA,然后选择第二个
![rmark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQyMTM2MjUw,size_16,color_FFFFFF,t_70)
g.cn/2019031119285370.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQyMTM2MjUw,size_16,color_FFFFFF,t_70)
此时可以验证一下,是否能获取这个EntityMangerFactory对象
创建一个产品domain,然后在测试类中,获取这个EntityMangerFactory对象,正常情况下,会在mysql下你设置的数据库中创建一个产品表,以下是我的一个简单测试
创建一个产品domain
@Entity
@Table(name = "product")
public class Product {
@Id
@GeneratedValue
private Long id;
private String name;
}
测试类中的部分核心代码:
@Autowired
private EntityManagerFactory factory;
@Test
public void test()throws Exception{
System.out.println(factory);
}
注意:
① 在实现类中配置@Repository,告诉Spring这是dao层
② 并注入EntityMangerFactory对象,然后实现接口的CRUD方法
③ 此时不能再使用@Autowired注入对象,必须使用@PersistenceContext持久化上下文注入EntityMangerFactory对象
常识:
① 事务是在service层开启(因为事务是一组同生共死的操作,三层中只有业务层才能满足同一组操作)
② 一次请求,就是一个线程,一个线程只需要一个EntityManger对象
③ @PersistenceContext会判断被标记的是什么对象,并去上下文中寻找(此处的上下文就是一次请求),如果没有需要的对象,会自动创建此对象,并将此对象放置在上下文中,保证一次请求中只有一个EntityManger对象。(备注:一个项目只需要一个EntityMangerFactory对象)
package cn.lzj.dao.impl;
import cn.lzj.dao.IProductDao;
import cn.lzj.domain.Product;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.PersistenceContext;
import java.util.List;
@Repository
public class ProductDaoImpl implements IProductDao {
@PersistenceContext
private EntityManager entityManager;
@Override
public void save(Product product) {
entityManager.persist(product);
}
@Override
public void update(Product product) {
entityManager.merge(product);
}
@Override
public void delete(Long id) {
Product product = findOne(id);
if(product!=null){
entityManager.remove(product);
}
}
@Override
public Product findOne(Long id) {
return entityManager.find(Product.class,id);
}
@Override
public List findAll() {
/* 使用JPQL查询数据 */
String jpql = "select o from Product o";
return entityManager.createQuery(jpql).getResultList();
}
}
xmlns:tx="http://www.springframework.org/schema/tx"
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd
propagation:事务传播机制
① Propagation.REQUIRED(必须的):默认调用这个方法的时候如果已经有事务了,咱们这个事务被包含到里面去调用这个方法的时候没有事务,就应该新开一个事务
② Propagation.REQUIRES_NEW:不管访问我的方法有没有事务,我都只开一个单独的事物
③ Propagation.NEVER(永不):绝对不能出现事务(如果出现,我就报错)
④ Propagation.SUPPORTS(支持):访问我如果有事务(支持) 如果没有事务(也支持)
package cn.lzj.service.impl;
import cn.lzj.dao.IProductDao;
import cn.lzj.domain.Product;
import cn.lzj.service.IProductService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
import java.util.List;
@Service
@Transactional
public class ProductServiceImpl implements IProductService {
@Autowired
private IProductDao productDao;
@Override
public void save(Product product) {
productDao.save(product);
}
@Override
public void update(Product product) {
productDao.update(product);
}
@Override
public void delete(Long id) {
productDao.delete(id);
}
/**
* readOnly = true:代表只读
* 添加之后,查询的性能会增加
*/
@Override
@Transactional(readOnly = true,propagation = Propagation.SUPPORTS)
public Product findOne(Long id) {
return productDao.findOne(id);
}
/**
* propagation:事务传播机制
* Propagation.REQUIRED(必须的):默认
* 调用这个方法的时候如果已经有事务了,咱们这个事务被包含到里面去
* 调用这个方法的时候没有事务,就应该新开一个事务
* Propagation.REQUIRES_NEW:不管访问我的方法有没有事务,我都只开一个单独的事物
* Propagation.NEVER(永不):绝对不能出现事务(如果出现,我就报错)
* Propagation.SUPPORTS(支持):访问我如果有事务(支持) 如果没有事务(也支持)
*/
@Override
@Transactional(readOnly = true,propagation = Propagation.SUPPORTS)
public List findAll() {
return productDao.findAll();
}
}
前提需要配置context的头和mvc的头
characterEncodingFilter
org.springframework.web.filter.CharacterEncodingFilter
encoding
UTF-8
forceEncoding
true
characterEncodingFilter
/*
org.springframework.web.context.ContextLoaderListener
contextConfigLocation
classpath:applicationContext.xml
dispatcherServlet
org.springframework.web.servlet.DispatcherServlet
contextConfigLocation
classpath:applicatioContext-mvc.xml
1
dispatcherServlet
/