use of org.nutz.dao.impl.entity.info.MappingInfo in project nutz by nutzam.
the class AnnotationEntityMaker method make.
public <T> Entity<T> make(Class<T> type) {
NutEntity<T> en = _createNutEntity(type);
TableInfo ti = _createTableInfo(type);
// 全局
if (null != expert.getConf()) {
for (String key : expert.getConf().keySet()) en.getMetas().put(key, expert.getConf().get(key));
}
// 当前表
if (null != ti.annMeta) {
Map<String, Object> map = Lang.map(ti.annMeta.value());
for (Entry<String, Object> entry : map.entrySet()) {
en.getMetas().put(entry.getKey(), entry.getValue().toString());
}
}
/*
* 获得表名以及视图名称及注释
*/
String tableName = null;
if (null == ti.annTable) {
tableName = Strings.lowerWord(type.getSimpleName(), '_');
if (null == ti.annView)
log.warnf("No @Table found, fallback to use table name='%s' for type '%s'", tableName, type.getName());
} else {
tableName = ti.annTable.value();
}
String viewName = null == ti.annView ? tableName : ti.annView.value();
en.setTableName(tableName);
en.setViewName(viewName);
boolean hasTableComment = null != ti.tableComment;
String tableComment = hasTableComment ? Strings.isBlank(ti.tableComment.value()) ? type.getName() : ti.tableComment.value() : null;
en.setHasTableComment(hasTableComment);
en.setTableComment(tableComment);
/*
* 获取所有的数据库字段
*/
// 字段里面是不是有声明过 '@Column' @Comment
boolean shouldUseColumn = false;
boolean hasColumnComment = false;
for (Field field : en.getMirror().getFields()) {
if (shouldUseColumn && hasColumnComment) {
break;
}
if (!shouldUseColumn && null != field.getAnnotation(Column.class)) {
shouldUseColumn = true;
}
if (!hasColumnComment && null != field.getAnnotation(Comment.class)) {
hasColumnComment = true;
}
}
en.setHasColumnComment(hasColumnComment);
/*
* 循环获取实体字段
*/
List<MappingInfo> infos = new ArrayList<MappingInfo>();
List<LinkInfo> ones = new ArrayList<LinkInfo>();
List<LinkInfo> manys = new ArrayList<LinkInfo>();
List<LinkInfo> manymanys = new ArrayList<LinkInfo>();
String[] _tmp = ti.annPK == null ? null : ti.annPK.value();
List<String> pks = _tmp == null ? new ArrayList<String>() : Arrays.asList(_tmp);
// 循环所有的字段,查找有没有数据库映射字段
for (Field field : en.getMirror().getFields()) {
// '@One'
if (null != field.getAnnotation(One.class)) {
ones.add(_Infos.createLinkInfo(field));
} else // '@Many'
if (null != field.getAnnotation(Many.class)) {
manys.add(_Infos.createLinkInfo(field));
} else // '@ManyMany'
if (null != field.getAnnotation(ManyMany.class)) {
manymanys.add(_Infos.createLinkInfo(field));
} else // 应该忽略
if ((Modifier.isTransient(field.getModifiers()) && null == field.getAnnotation(Column.class)) || (shouldUseColumn && (null == field.getAnnotation(Column.class) && null == field.getAnnotation(Id.class) && null == field.getAnnotation(Name.class))) && !pks.contains(field.getName())) {
continue;
} else // '@Column'
{
infos.add(_Infos.createMappingInfo(ti.annPK, field));
}
}
// 循环所有方法,查找有没有虚拟数据库映射字段
for (Method method : en.getType().getMethods()) {
// '@One'
if (null != method.getAnnotation(One.class)) {
ones.add(_Infos.createLinkInfo(method));
} else // '@Many'
if (null != method.getAnnotation(Many.class)) {
manys.add(_Infos.createLinkInfo(method));
} else // '@ManyMany'
if (null != method.getAnnotation(ManyMany.class)) {
manymanys.add(_Infos.createLinkInfo(method));
} else // 应该忽略
if (null == method.getAnnotation(Column.class) && null == method.getAnnotation(Id.class) && null == method.getAnnotation(Name.class)) {
continue;
} else // '@Column'
{
infos.add(_Infos.createMapingInfo(ti.annPK, method));
}
}
// 给字段排序一下, fix issue #29
List<MappingInfo> tmp = new ArrayList<MappingInfo>(infos.size());
MappingInfo miId = null;
MappingInfo miName = null;
for (MappingInfo mi : infos) {
if (mi.annId != null) {
if (miId != null) {
throw new DaoException("Allows only a single @Id ! " + type);
}
miId = mi;
} else if (mi.annName != null) {
if (miName != null) {
throw new DaoException("Allows only a single @Name ! " + type);
}
miName = mi;
} else
tmp.add(mi);
}
if (miName != null)
tmp.add(0, miName);
if (miId != null)
tmp.add(0, miId);
infos = tmp;
// 映射字段搞完了? 我看看你到底有没有字段!!
if (infos.isEmpty())
throw Lang.makeThrow(IllegalArgumentException.class, "Pojo(%s) without any Mapping Field!!", type);
/*
* 解析所有映射字段
*/
for (MappingInfo info : infos) {
NutMappingField ef = new NutMappingField(en);
_evalMappingField(ef, info);
en.addMappingField(ef);
}
// 保存一下,这样别的实体映射到这里时会用的到
holder.set(en);
try {
// 一对一 '@One'
for (LinkInfo li : ones) {
en.addLinkField(new OneLinkField(en, holder, li));
}
// 一对多 '@Many'
for (LinkInfo li : manys) {
en.addLinkField(new ManyLinkField(en, holder, li));
}
// 多对多 '@ManyMany'
for (LinkInfo li : manymanys) {
en.addLinkField(new ManyManyLinkField(en, holder, li));
}
// 检查复合主键
en.checkCompositeFields(null == ti.annPK ? null : ti.annPK.value());
/*
* 交付给 expert 来检查一下数据库一致性
*/
if (null != datasource && null != expert) {
_checkupEntityFieldsWithDatabase(en);
}
/*
* 检查字段宏
*/
_evalFieldMacro(en, infos);
/*
* 解析实体索引
*/
if (null != ti.annIndexes)
_evalEntityIndexes(en, ti.annIndexes);
} catch (RuntimeException e) {
holder.remove(en);
throw e;
} catch (Throwable e) {
holder.remove(en);
throw Lang.wrapThrow(e);
}
// 搞定收工,哦耶 ^_^
en.setComplete(true);
return en;
}
use of org.nutz.dao.impl.entity.info.MappingInfo in project nutz by nutzam.
the class AnnotationEntityMaker method _evalFieldMacro.
private void _evalFieldMacro(Entity<?> en, List<MappingInfo> infos) {
for (MappingInfo info : infos) {
// '@Prev' : 预设值
if (null != info.annPrev) {
boolean flag = en.addBeforeInsertMacro(__macro(en.getField(info.name), _annToFieldMacroInfo(info.annPrev.els(), info.annPrev.value())));
if (flag && null != info.annId && info.annId.auto()) {
log.debugf("Field(%s#%s) autoset as @Id(auto=false)", en.getType().getName(), info.name);
((NutMappingField) en.getField(info.name)).setAutoIncreasement(false);
}
}
// '@Next' : 后续获取
if (null != info.annNext && en.addAfterInsertMacro(__macro(en.getField(info.name), _annToFieldMacroInfo(info.annNext.els(), info.annNext.value())))) {
continue;
} else // '@Id' : 的自动后续获取
if (null != info.annId && info.annId.auto() && en.getField(info.name).isAutoIncreasement()) {
if (!expert.isSupportAutoIncrement() || !expert.isSupportGeneratedKeys())
en.addAfterInsertMacro(expert.fetchPojoId(en, en.getField(info.name)));
}
}
}
Aggregations