数据库笔记

本文探讨了在使用JPA进行数据库操作时遇到的Duplicateentry'0'forkey'PRIMARY'错误及其解决方案,并介绍了如何正确配置实体类的自增长主键。此外,还提供了在Java中快速解析包含JSON数组的JSON对象的方法。

Duplicate entry '0' for key 'PRIMARY'错误

自动增量问题

JPA的注解来定义实体的时候,使用@Id来注解主键属性即可。如果数据库主键是自增长的,需要在增加一个注解@GeneratedValue,即:

1     @GeneratedValue(strategy=GenerationType.IDENTITY)
2     @Id
3     private String id;

 

PS:@GeneratedValue注解的strategy属性提供四种值:

–AUTO: 主键由程序控制,是默认选项,不设置即此项。

–IDENTITY:主键由数据库自动生成,即采用数据库ID自增长的方式,Oracle不支持这种方式。

–SEQUENCE:通过数据库的序列产生主键,通过@SequenceGenerator 注解指定序列名,mysql不支持这种方式。

–TABLE:通过特定的数据库表产生主键,使用该策略可以使应用更易于数据库移植。

也可以手动设置主键自动增长

mvn spring-boot:run运行spring-boot

 {  
                    "username":"hjc",  
                    "creadate":"234",  
                    "foods": 
                        [ 
                            {"name": "xilanhua ","weight" :"3 ","flag":"1"}, 
                            { "name":"doujiang ","weight": "1 ","flag":"2"} 
                        ]
                 
                }

json数据传输数组的格式,json对空格很敏感,比如“creadate  ”这种加空格传输后,获取jsonObject.getString("creadate")方式是不行的

JAVA中快速解析JSON对象里包含的JSON数组

例如现在有这样一个Json

String Value =  {"data":[{"school_name":"西北农林科技大学","school_id":"8"},{"school_name":"西北大学","school_id":"6"},

{"school_name":"西北工业大学","school_id":"5"},{"school_name":"西北政法大学","school_id":"2"},{"school_name":"西安交通大学","school_id":"4"},{"school_name":"西安建筑科技大学","school_id":"10"},{"school_name":"西安电子科技大学","school_id":"3"},{"school_name":"西安邮电大学","school_id":"1"},{"school_name":"长安大学","school_id":"9"},{"school_name":"陕西师范大学","school_id":"7"},{"school_name":"陕西科技大学","school_id":"11"}],"msg":"列表获取成功","status":0}

用2个数组接收school_name和school_id

首先         

             public   String[] schoolID; 
             public  String[] schoolName;

             JSONObject  jsonObj_school;//用来接收解析的JSON字符串

              JSONArray  jsonArr_school ;//用来接收JSON对象里的数组

        try{
jsonObj_school = new JSONObject ( Value ); //解析JSON字符串
jsonArr_school  =jsonObj_school.getJSONArray("data");//接收JSON对象里的数组
   int jsonSize_school = jsonArr_school.length();.//获取数组长度
   schoolID = new String[ jsonSize_school ];//初始化数组
  schoolName = new String[ jsonSize_school];//初始化数组
  for(int i = 0; i < jsonSize_school; i++ )//通过循环取出数组里的值
  {
 JSONObject jsonTemp = (JSONObject)jsonArr_school.getJSONObject(i);
   schoolID[i] = jsonTemp.getString("school_id");
   schoolName[i] = jsonTemp.getString("school_name");
   }

            }

               catch(Exception e){
e.printStackTrace();
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值