比如同时支持oracle和sql server?
请教大侠高手指点!(不用字符串)

解决方案 »

  1.   

    用程序创建的话,建议用JPA,主键属性上声明个Annotation标签,系统自动帮你创建
      

  2.   

          你都两个数据库了  那就可以生成两个主键     关键的时候  你要在程序中写代码啊   如果是sql数据库的话  让代码执行   你要生成的主键        如果是oracle的话 让代码另外执行  不就多一个if else 
      

  3.   

    这是我收藏的一个主键生成类,楼主可以拿去用:
    import java.io.Serializable;
    import java.net.InetAddress;/**
     * 生成类似hibernate中uuid 32位主键序列
     * 
     * @version: V1.0
     */
    public class UUIDGenerator { private static final int IP; public static int IptoInt(byte[] bytes) {
    int result = 0;
    for (int i = 0; i < 4; i++) {
    result = (result << 8) - Byte.MIN_VALUE + (int) bytes[i];
    }
    return result;
    } static {
    int ipadd;
    try {
    ipadd = IptoInt(InetAddress.getLocalHost().getAddress());
    } catch (Exception e) {
    ipadd = 0;
    }
    IP = ipadd;
    }
    private static short counter = (short) 0;
    private static final int JVM = (int) (System.currentTimeMillis() >>> 8); public UUIDGenerator() {
    }
    public static int getJVM() {
    return JVM;
    }
    public static short getCount() {
    synchronized (UUIDGenerator.class) {
    if (counter < 0)
    counter = 0;
    return counter++;
    }
    }
    public static int getIP() {
    return IP;
    }
    public static short getHiTime() {
    return (short) (System.currentTimeMillis() >>> 32);
    } public static int getLoTime() {
    return (int) System.currentTimeMillis();
    } private final static String sep = ""; public static String format(int intval) {
    String formatted = Integer.toHexString(intval);
    StringBuffer buf = new StringBuffer("00000000");
    buf.replace(8 - formatted.length(), 8, formatted);
    return buf.toString();
    } public  static String format(short shortval) {
    String formatted = Integer.toHexString(shortval);
    StringBuffer buf = new StringBuffer("0000");
    buf.replace(4 - formatted.length(), 4, formatted);
    return buf.toString();
    } public static String generate() {
    return String.valueOf(new StringBuffer(36).append(format(getIP())).append(sep)
    .append(format(getJVM())).append(sep)
    .append(format(getHiTime())).append(sep)
    .append(format(getLoTime())).append(sep)
    .append(format(getCount())).toString());
    }
    public static void main(String args[]){
    System.out.println(UUIDGenerator.generate());
    }
    }
      

  4.   

                    @Id
                    @GeneratedValue(strategy = GenerationType.AUTO)
                    private Long id;
    配置sessionFactory时,有packagesToScan属性:                <property name="packagesToScan">
    <list>
    <value>com.jandar.domain</value>
    </list>
    </property>
    另外,首次加载应用时,hibernate.hbm2ddl.auto设置成create,以后设置成update或none。
      

  5.   

    可以自己写一个主键生成器,获取当前的时间时分秒:yyyymmddHHMMSS,后面还可以根据需要加个几位的随机字符串