我按如下方式对接口进行编码:
DAO界面:
public interface SampleTblDao extends BaseDao<SampleTbl> {
/**
*
* @param mapper
* @param sampleKey
* @return
* @throws DataAccessException
*/
public SampleTbl selectSampleTbl(SampleKey sampleKey) throws DataAccessException;
}
DAO实施
public class SampleTblDaoImpl extends AbstractBaseDao<SampleTbl, SampleTblMapper> implements SampleTblDao {
public SampleTblDaoImpl() {
super(SampleTblMapper.class);
}
@Override
public SampleTbl selectSampleTbl(SampleKey sampleKey) throws DataAccessException {
return getSqlSession().getMapper(SampleTblMapper.class).selectSampleTbl(sampleKey);
}
}
业务逻辑界面:
public interface SampleBusinessLogic {
/**
*
* @param sample
* @return
* @throws SampleException
*/
public Sample createSample(Sample sample) throws SampleException;
/**
*
* @param sample
* @return
* @throws SampleException
*/
public Sample updateSample(Sample sample) throws SampleException;
/**
* @param sampleKey
* @return
* @throws SampleException
*/
public Sample getSample(SampleKey sampleKey) throws SampleException;
}
业务逻辑实施:
public class SampleBusinessLogicImpl implements SampleBusinessLogic {
/**
* sample table dao
*/
@Autowired
@Qualifier(value = "sampleTblDao")
private SampleTblDao sampleTblDao;
@Override
@Transactional(rollbackFor = Exception.class)
public Sample createSample(Sample sample) throws SampleException {
try {
// sample table
createSampleTbl(sample.getSampleTbl());
} catch (Exception e) {
List < String > messageList = new ArrayList < String > ();
String message = "{createSample : " + "{itemId=" + sample.getSampleTbl().getItemId() + "}," + "{itemName=" + sample.getSampleTbl().getItemName() + "}}";
messageList.add("createShop system error");
throw new SampleException(message, messageList, e);
}
return sample;
}
@Override
@Transactional(rollbackFor = Exception.class)
public Sample updateSample(Sample sample) throws SampleException {
List < String > messageList = null;
String message = null;
try {
// global shop table
updateSampleTbl(sample.getSampleTbl());
} catch (IllegalDataException e) {
message = "{updateSample : " + "{itemId=" + sample.getSampleTbl().getItemId() + "}," + "{itemName=" + sample.getSampleTbl().getItemName() + "}}";
messageList = new ArrayList < String > ();
messageList.add("updateSample illegal data error");
throw new SampleException(message, messageList, e);
} catch (Exception e) {
message = "{updateSample : " + "{itemId=" + sample.getSampleTbl().getItemId() + "}," + "{itemName=" + sample.getSampleTbl().getItemName() + "}}";
messageList = new ArrayList < String > ();
messageList.add("updateSample system error");
throw new SampleException(message, messageList, e);
}
return sample;
}
@Override
@Transactional(rollbackFor = Exception.class, readOnly = true)
public Sample getSample(SampleKey sampleKey) throws SampleException {
Sample sample = new Sample();
String message = null;
List < String > messageList = null;
try {
sample.setSampleTbl(getSampleTbl(sampleKey));
} catch (DataNotFoundException e) {
message = "{getSample : " + "{itemId=" + sampleKey.getItemId() + "}}";
messageList = new ArrayList < String > ();
messageList.add("getSample data not found error");
throw new SampleException(message, messageList, e);
} catch (Exception e) {
message = "{getSample : " + "{itemId=" + sampleKey.getItemId() + "}}";
messageList = new ArrayList < String > ();
messageList.add("getSample system error");
throw new SampleException(message, messageList, e);
}
return sample;
}
/**
*
* @param sampleTbl
* @throws Exception
*/
private void createSampleTbl(SampleTbl sampleTbl) throws Exception {
sampleTbl.setItemId(new UUID().toString());
sampleTblDao.insert(sampleTbl);
}
/**
* @param sampleTbl
* @throws Exception
*/
private void updateSampleTbl(SampleTbl sampleTbl) throws Exception {
if (sampleTbl.isTransactionTarget(SampleTbl.class)) {
String message = null;
SampleKey sampleKey = new SampleKey();
sampleKey.setItemId(sampleTbl.getItemId());
SampleTbl sampleTblPre = sampleTblDao.selectSampleTbl(sampleKey);
if (sampleTblPre == null) {
// if sample table is empty
message = "{illegal data error:{sampleTblPre=null}}";
throw new IllegalDataException(message);
}
sampleTbl.setItemId(sampleTblPre.getItemId());
sampleTblDao.update(sampleTbl);
}
}
/**
* @param sampleKey
* @return
* @throws Exception
*/
private SampleTbl getSampleTbl(SampleKey sampleKey) throws Exception {
String message = "";
SampleTbl sampleTbl = sampleTblDao.selectSampleTbl(sampleKey);
if (sampleTbl == null) {
// if sample tbl is empty
message = "{data not found error:{SampleTbl=null}}";
throw new DataNotFoundException(message);
}
return sampleTbl;
}
public void setSampleTblDao(SampleTblDao sampleTblDao) {
this.sampleTblDao = sampleTblDao;
}
}
在应用程序上下文XML中,我按如下方式配置了bean:
<bean id="sampleTblDao" class="com.rakuten.gep.sample.dao.impl.SampleTblDaoImpl" parent="baseDAO" scope="singleton">
<property name="namespace" value="com.rakuten.gep.sample.dao.mapper.SampleTblMapper" />
</bean>
<bean id="sampleBusinessLogic" class="com.rakuten.gep.sample.businesslogic.impl.SampleBusinessLogicImpl" scope="singleton"/>
<!-- and annocation based transaction is configured as follows -->
<tx:annotation-driven transaction-manager="trx-manager" proxy-target-class="true" />
<bean id="trx-manager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
但是在调试之后,我意识到在'SampleBusinessLogicImpl'中的自动连接字段'sampleTblDao'始终为null。
任何提示?
答案 0 :(得分:4)
您正在使用XML配置内容并依赖(部分)注释。默认情况下,spring会忽略所有注释,例如@Autowired
,@Inject
等。要启用这些注释的处理,需要注册AutowiredAnnotationBeanPostProcessor
和CommonAnnotationBeanPostProcessor
(后者用于@Resource
和其他JSR-250注释处理)的实例。
这可以手动完成,也可以使用命名空间。
<context:annotation-config />
当使用<context:component-scan />
时,已经暗示人们想要使用注释进行配置,因此<context:annotation-config />
的功能已经包含在内,因此无需再次添加。