数据库笔记

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"} 
                        ]
                 
                }

扫描二维码关注公众号,回复: 2518856 查看本文章

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();
}

猜你喜欢

转载自blog.csdn.net/qq_36734094/article/details/81144670