当时用逆向生成后,实体类中的下划线都被去掉,这时只需要在sqlmap.xml中加以下代码即可。打开mybatis驼峰法则。 settings !-- 打印查询语句 -- setting name="logImpl" value="STDOUT_LOGGING" / !-- 是否
当时用逆向生成后,实体类中的下划线都被去掉,这时只需要在sqlmap.xml中加以下代码即可。打开mybatis驼峰法则。
<settings> <!-- 打印查询语句 --> <setting name="logImpl" value="STDOUT_LOGGING" /> <!-- 是否开启自动驼峰命名规则(camel case)映射,即从经典数据库列名 A_COLUMN 到经典Java 属性名 aColumn 的类似映射 --> <setting name="mapUnderscoreToCamelCase" value="true"/> </settings>
补充知识:【Java】Iterator接口方法及 独立类迭代器实现
接口实现:
Iterator接口包含三个方法:hasNext、next、remove。
迭代器的位置不是在某一个元素上,而是在集合中第一个元素之前、两个元素之间或最后一个元素之后。
public interface Iterator<T> { /** * Task:测定迭代器是否完成遍历并越过数据集的最后一个元素 * @return 迭代器若有下一个元素返回 true */ public boolean hasNext(); /** * Task:提取集合中当前(下一个)元素 并迭代前进下一个位置 * @return 迭代当前元素的引用 * @throws java.util.NoSuchElementException 若迭代已经到头,则 hasNext()为false */ public T next(); /** * Task:从迭代器删除next()返回的下一个元素 * 此后调用next()的行为将与删除前一样 * Precondition:next()已被调用,remove()尚未被调用 * 数据集在迭代期间 除调用本方法外未被修改 * @throws IllegalStateException 若next()未被调用 * @throws UnsupportedOperationException 若迭代器不允许删除 */ public void remove(); }
独立类迭代器实现:
import java.util.ArrayList; import java.util.NoSuchElementException; /** * 独立类迭代器 * @param <T> */ public class SeparateIterator<T> implements Iterator<T> { private ArrayList<T> list; private int nextPosition; //next()返回最近元素的位置 private boolean wasNextCalled; //需要删除的 public SeparateIterator(ArrayList<T> arrayList) { list=arrayList; nextPosition=0; //用于跟踪迭代到何处 wasNextCalled=false; //用于检出是否首先调用了next() } @Override public boolean hasNext() { return nextPosition<list.size(); } @Override public T next() { if(hasNext()) { wasNextCalled = true; //设置为true,remove()方法可以调用next() nextPosition++; return list.get(nextPosition-1); //由于先前移,故减一 } else throw new NoSuchElementException("Illegal call to next();"+"iterator is after end of list!"); } @Override public void remove() { if(wasNextCalled){ list.remove(nextPosition); nextPosition--; wasNextCalled=false; } else throw new IllegalStateException("Illegal call to remove();"+"next() was not called!"); } }
测试:
注意调用SeparateIterator的构造函数将迭代器nameofGQT与线性表nameList连接起来。
import java.util.ArrayList; public class Test { public static void main(String[] args){ ArrayList<String> arrayList=new ArrayList<String>(); arrayList.add("Ned"); arrayList.add("John"); arrayList.add("Robb"); arrayList.add("Sansa"); arrayList.add("Arya"); arrayList.add("Bran"); for (String s:arrayList) { //输出 System.out.println(s); } System.out.println(); Iterator<String> nameofGQT=new SeparateIterator<String>(arrayList); //调用SeparateIterator的构造函数把迭代器namwodGQT与arrayList连接在一起 // while (nameofGQT.hasNext()) // System.out.print(nameofGQT.next()+" "); //用于测试,否则会抛出NoSuchElementException异常 // System.out.println(); nameofGQT.next(); //The old wolf is gone! Poor Ned! // while (nameofGQT.hasNext()) // System.out.print(nameofGQT.next()+" "); //用于测试,否则会报出NoSuchElementException异常 // System.out.println(); nameofGQT.next(); nameofGQT.remove(); //The Young Wolf is dead! //nameofGQT.remove(); //出错,未先使用next(),报出IllegalStateException异常 while (nameofGQT.hasNext()) System.out.print(nameofGQT.next()+" "); } }
以上这篇mybatis 逆向生成后遵循java驼峰法则的解决就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持易盾网络。