sequencesqlmapdao.java

来自「JAVA 文章管理系统源码」· Java 代码 · 共 51 行

JAVA
51
字号
/**
 * User: Clinton Begin
 * Date: Jul 13, 2003
 * Time: 7:21:30 PM
 */
package com.haven.sinopec.persistence.sqlmapdao;

import com.ibatis.dao.client.DaoException;
import com.ibatis.dao.client.DaoManager;

import com.haven.sinopec.domain.Sequence;
import com.haven.sinopec.persistence.iface.SequenceDao;

public class SequenceSqlMapDao extends BaseSqlMapDao implements SequenceDao {

  public SequenceSqlMapDao(DaoManager daoManager) {
    super(daoManager);
  }

  /**
   * This is a generic sequence ID generator that is based on a database
   * table called 'SEQUENCE', which contains two columns (NAME, NEXTID).
   * <p/>
   * This approach should work with any database.
   *
   * @param name The name of the sequence.
   * @return The Next ID
   * @
   */
  public synchronized int getNextId(String name) {
    Sequence sequence = new Sequence(name, 1);

    sequence = (Sequence) queryForObject("getSequence", sequence);
    if (sequence == null) {
      //throw new DaoException("Error: A null sequence was returned from the database (could not get next " + name + " sequence).");
    	Object parameterObject1 = new Sequence(name, 2);
    	try{
        insert("insertSequence", parameterObject1);
    	}catch(Exception e){
    		e.printStackTrace();
    	}
    }
    Object parameterObject = new Sequence(name, sequence.getNextId() + 1);
    update("updateSequence", parameterObject);

    return sequence.getNextId();
  }
 
  
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?