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驼峰法则的解决就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
以上是 mybatis 逆向生成后遵循java驼峰法则的解决 的全部内容, 来源链接: utcz.com/z/350588.html