mybatis 逆向生成后遵循java驼峰法则的解决
当时用逆向生成后,实体类中的下划线都被去掉,这时只需要在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驼峰法则的解决就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持好吧啦网。
相关文章: