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

回到顶部