use of org.nutz.dao.DaoException in project nutz by nutzam.
the class NutDaoRunner method _runWithTransaction.
protected void _runWithTransaction(Transaction t, DataSource dataSource, ConnCallback callback) {
Connection conn = null;
Savepoint sp = null;
try {
conn = t.getConnection(selectDataSource(t, dataSource, callback));
if (meta != null && meta.isPostgresql()) {
sp = conn.setSavepoint();
}
runCallback(conn, callback);
} catch (Exception e) {
if (sp != null && conn != null)
try {
conn.rollback(sp);
} catch (SQLException e1) {
}
if (e instanceof DaoException)
throw (DaoException) e;
throw new DaoException(e);
}
}
use of org.nutz.dao.DaoException in project nutz by nutzam.
the class BoneCP_Test method clear_links.
@Test
public void clear_links() {
dao.create(Pet.class, true);
Sql sql1 = Sqls.create("INSERT INTO t_pet (name) VALUES ('A')");
Sql sql2 = Sqls.create("INSERT INTO t_pet (nocol) VALUES ('B')");
try {
dao.execute(sql1, sql2);
fail();
} catch (DaoException e) {
}
assertEquals(0, dao.count(Pet.class));
}
use of org.nutz.dao.DaoException in project nutz by nutzam.
the class FileSqlManager method addSql.
public synchronized void addSql(String key, String value) {
log.debugf("key=[%s], sql=[%s]", key, value);
if (!isAllowDuplicate() && sqls.containsKey(key))
throw new DaoException("Duplicate sql key=[" + key + "]");
sqls.put(key, value);
}
use of org.nutz.dao.DaoException in project nutz by nutzam.
the class NutDao method setExpert.
// ---------------------------------------------------------------
// 专属于NutDao的一些帮助方法
public void setExpert(Object obj) throws Exception {
if (obj == null)
throw new NullPointerException("expert MUST NOT NULL!!");
if (obj instanceof JdbcExpert) {
this.expert = (JdbcExpert) obj;
} else {
String name = obj.toString();
this.expert = Jdbcs.getExpert(name, "");
if (this.expert == null) {
if (name.contains(".")) {
this.expert = (JdbcExpert) Lang.loadClass(name).newInstance();
} else {
throw new DaoException("not such expert=" + obj);
}
}
}
DataSource ds = this.dataSource;
// 如果数据源比expert先设置,那么需要重新设置一次
if (ds != null) {
this.dataSource = null;
setDataSource(ds);
}
}
use of org.nutz.dao.DaoException 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;
}
Aggregations