javajson串查询的简单介绍

本文目录一览:

怎样在java中查询mysql得到如下的json格式的结果

怎样在java中查询mysql得到如下的json格式的结果

Java中查询出来一般不会是JSON,都是Object。你要把Object返回给前端或者客户端的时候,用Jackson或者FastJSON把Object转换成JSON格式。不知道你想在哪用JSON,所以只能这么回答了。

java中mongodb嵌套json查询?

fastjson-1.1.2.jar 可以用这个jar包实现 java里面 json字符串和对象之间的互转

javaweb json字符串提取对象数据

在model层

public ListMapString,String query() throws SQLException

{

ListMapString,String listmap=new ArrayListMapString,String();

Connection conn=null;

ResultSet rs=null;

String query=”SELECT * FROM COURSE”;

Statement st=null;

conn=Conn.getConnection();

st=conn.createStatement();

rs=st.executeQuery(query);

while(rs.next())

{

MapString,String map=new HashMapString, String();

map.put(“coursetypeid”, rs.getString(“COURSE_TYPE_ID”));

map.put(“coursename”, rs.getString(“COURSE_NAME”));

map.put(“publish”, rs.getString(“PUBLISH”));

map.put(“publishtime”, rs.getString(“PUBLISH_TIME”));

map.put(“coursenumber”, rs.getString(“CHAPTER_NUMBER”));

map.put(“courseid”, rs.getString(“COURSE_ID”));

map.put(“coursedesc”, rs.getString(“COURSE_DESC”));

listmap.add(map);

}

conn.close();

return listmap;

}

java解析json字符串数据

这个需要导入个jar包的,自己写太麻烦,而且要考虑特殊字符的转义的。

1. json-lib是一个java类库,提供将Java对象,包括beans, maps, collections, java arrays and XML等转换成JSON,或者反向转换的功能。

2. json-lib 主页 : 

3.执行环境

需要以下类库支持

jakarta commons-lang 2.5

jakarta commons-beanutils 1.8.0

jakarta commons-collections 3.2.1

jakarta commons-logging 1.1.1

ezmorph 1.0.6

4.功能示例

这里通过JUnit-Case例子给出代码示例

  

package com.mai.json;

import static org.junit.Assert.assertEquals;

import java.util.ArrayList;

import java.util.Date;

import java.util.HashMap;

import java.util.Iterator;

import java.util.List;

import java.util.Map;

import net.sf.ezmorph.Morpher;

import net.sf.ezmorph.MorpherRegistry;

import net.sf.ezmorph.bean.BeanMorpher;

import net.sf.json.JSONArray;

import net.sf.json.JSONObject;

import net.sf.json.util.JSONUtils;

import org.apache.commons.beanutils.PropertyUtils;

import org.junit.Test;

public class JsonLibTest {

    /*

     *  普通类型、List、Collection等都是用JSONArray解析

     *  

     *  Map、自定义类型是用JSONObject解析

     *  可以将Map理解成一个对象,里面的key/value对可以理解成对象的属性/属性值

     *  即{key1:value1,key2,value2……}

     * 

     * 1.JSONObject是一个name:values集合,通过它的get(key)方法取得的是key后对应的value部分(字符串)

     *         通过它的getJSONObject(key)可以取到一个JSONObject,– 转换成map,

     *         通过它的getJSONArray(key) 可以取到一个JSONArray ,

     * 

     * 

     */

    

    //一般数组转换成JSON

    @Test

    public void testArrayToJSON(){

        boolean[] boolArray = new boolean[]{true,false,true};  

        JSONArray jsonArray = JSONArray.fromObject( boolArray );  

        System.out.println( jsonArray );  

        // prints [true,false,true]  

    }

    

    

    //Collection对象转换成JSON

    @Test

    public void testListToJSON(){

        List list = new ArrayList();  

        list.add( “first” );  

        list.add( “second” );  

        JSONArray jsonArray = JSONArray.fromObject( list );  

        System.out.println( jsonArray );  

        // prints [“first”,”second”]  

    }

    

    

    //字符串json转换成json, 根据情况是用JSONArray或JSONObject

    @Test

    public void testJsonStrToJSON(){

        JSONArray jsonArray = JSONArray.fromObject( “[‘json’,’is’,’easy’]” );  

        System.out.println( jsonArray );  

        // prints [“json”,”is”,”easy”]  

    }

    

    

    //Map转换成json, 是用jsonObject

    @Test

    public void testMapToJSON(){

        Map map = new HashMap();  

        map.put( “name”, “json” );  

        map.put( “bool”, Boolean.TRUE );  

        map.put( “int”, new Integer(1) );  

        map.put( “arr”, new String[]{“a”,”b”} );  

        map.put( “func”, “function(i){ return this.arr[i]; }” );  

          

        JSONObject jsonObject = JSONObject.fromObject( map );  

        System.out.println( jsonObject );  

    }

    

    //复合类型bean转成成json

    @Test

    public void testBeadToJSON(){

        MyBean bean = new MyBean();

        bean.setId(“001”);

        bean.setName(“银行卡”);

        bean.setDate(new Date());

        

        List cardNum = new ArrayList();

        cardNum.add(“农行”);

        cardNum.add(“工行”);

        cardNum.add(“建行”);

        cardNum.add(new Person(“test”));

        

        bean.setCardNum(cardNum);

        

        JSONObject jsonObject = JSONObject.fromObject(bean);

        System.out.println(jsonObject);

        

    }

    

    //普通类型的json转换成对象

    @Test

    public void testJSONToObject() throws Exception{

        String json = “{name=\”json\”,bool:true,int:1,double:2.2,func:function(a){ return a; },array:[1,2]}”;  

        JSONObject jsonObject = JSONObject.fromObject( json ); 

        System.out.println(jsonObject);

        Object bean = JSONObject.toBean( jsonObject ); 

        assertEquals( jsonObject.get( “name” ), PropertyUtils.getProperty( bean, “name” ) );  

        assertEquals( jsonObject.get( “bool” ), PropertyUtils.getProperty( bean, “bool” ) );  

        assertEquals( jsonObject.get( “int” ), PropertyUtils.getProperty( bean, “int” ) );  

        assertEquals( jsonObject.get( “double” ), PropertyUtils.getProperty( bean, “double” ) );  

        assertEquals( jsonObject.get( “func” ), PropertyUtils.getProperty( bean, “func” ) );  

        System.out.println(PropertyUtils.getProperty(bean, “name”));

        System.out.println(PropertyUtils.getProperty(bean, “bool”));

        System.out.println(PropertyUtils.getProperty(bean, “int”));

        System.out.println(PropertyUtils.getProperty(bean, “double”));

        System.out.println(PropertyUtils.getProperty(bean, “func”));

        System.out.println(PropertyUtils.getProperty(bean, “array”));

        

        List arrayList = (List)JSONArray.toCollection(jsonObject.getJSONArray(“array”));

        for(Object object : arrayList){

            System.out.println(object);

        }

        

    }

    

    

    //将json解析成复合类型对象, 包含List

    @Test

    public void testJSONToBeanHavaList(){

        String json = “{list:[{name:’test1′},{name:’test2′}],map:{test1:{name:’test1′},test2:{name:’test2′}}}”;

//        String json = “{list:[{name:’test1′},{name:’test2′}]}”;

        Map classMap = new HashMap();

        classMap.put(“list”, Person.class);

        MyBeanWithPerson diyBean = (MyBeanWithPerson)JSONObject.toBean(JSONObject.fromObject(json),MyBeanWithPerson.class , classMap);

        System.out.println(diyBean);

        

        List list = diyBean.getList();

        for(Object o : list){

            if(o instanceof Person){

                Person p = (Person)o;

                System.out.println(p.getName());

            }

        }

    }

    

    

    //将json解析成复合类型对象, 包含Map

    @Test

    public void testJSONToBeanHavaMap(){

        //把Map看成一个对象

        String json = “{list:[{name:’test1′},{name:’test2′}],map:{testOne:{name:’test1′},testTwo:{name:’test2′}}}”;

        Map classMap = new HashMap();

        classMap.put(“list”, Person.class);

        classMap.put(“map”, Map.class);

        //使用暗示,直接将json解析为指定自定义对象,其中List完全解析,Map没有完全解析

        MyBeanWithPerson diyBean = (MyBeanWithPerson)JSONObject.toBean(JSONObject.fromObject(json),MyBeanWithPerson.class , classMap);

        System.out.println(diyBean);

        

        System.out.println(“do the list release”);

        ListPerson list = diyBean.getList();

        for(Person o : list){

            Person p = (Person)o;

            System.out.println(p.getName());

        }

        

        System.out.println(“do the map release”);

        

        //先往注册器中注册变换器,需要用到ezmorph包中的类

        MorpherRegistry morpherRegistry = JSONUtils.getMorpherRegistry();

        Morpher dynaMorpher = new BeanMorpher( Person.class,  morpherRegistry);  

        morpherRegistry.registerMorpher( dynaMorpher );  

        

        

        Map map = diyBean.getMap();

        /*这里的map没进行类型暗示,故按默认的,里面存的为net.sf.ezmorph.bean.MorphDynaBean类型的对象*/

        System.out.println(map);

/*输出:

{testOne=net.sf.ezmorph.bean.MorphDynaBean@f73c1[

  {name=test1}

], testTwo=net.sf.ezmorph.bean.MorphDynaBean@186c6b2[

  {name=test2}

]}

*/

        ListPerson output = new ArrayList();  

        for( Iterator i = map.values().iterator(); i.hasNext(); ){  

            //使用注册器对指定DynaBean进行对象变换

           output.add( (Person)morpherRegistry.morph( Person.class, i.next() ) );  

        }  

        

        for(Person p : output){

            System.out.println(p.getName());

/*输出:

test1

test2

*/

        }

        

    }

    

    

    

}

关于Java处理JSON字符串的新手问题

第一点:你既然使用了net.sf.json.JSONObject对象引入了jar包直接使用其的fromObject将对象转为字符串效率更高,出错的概率也更小一些。

第二点:对象中套对象的方式也很简单,如这样

public static void main(String[] args) {

Map map1 = new HashMap();

Map map2 = new HashMap();

Map map3 = new HashMap();

map3.put(“value”,”Male”);

map2.put(“gender”,map3);

map1.put(“attributes”,map2);

JSONObject json = JSONObject.fromObject(map1);

System.out.println(json);

}

第三点:将字符串解析回来。

Object obj2 = JSONObject.toBean(json,Map.class);

Map map = (Map) obj2;

MorphDynaBean map4 = (MorphDynaBean) map.get(“attributes”);

MorphDynaBean map5 = (MorphDynaBean) map4.get(“gender”);

String male = (String) map5.get(“value”);

System.out.println(male);

第四点:

可以参考:网页链接

或者百度搜索:java操作json数据之net.sf.json-lib 经验

原创文章,作者:GUPR,如若转载,请注明出处:https://www.506064.com/n/146067.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
GUPRGUPR
上一篇 2024-10-29 18:57
下一篇 2024-10-29 18:57

相关推荐

  • Python简单数学计算

    本文将从多个方面介绍Python的简单数学计算,包括基础运算符、函数、库以及实际应用场景。 一、基础运算符 Python提供了基础的算术运算符,包括加(+)、减(-)、乘(*)、除…

    编程 2025-04-29
  • Python满天星代码:让编程变得更加简单

    本文将从多个方面详细阐述Python满天星代码,为大家介绍它的优点以及如何在编程中使用。无论是刚刚接触编程还是资深程序员,都能从中获得一定的收获。 一、简介 Python满天星代码…

    编程 2025-04-29
  • Python海龟代码简单画图

    本文将介绍如何使用Python的海龟库进行简单画图,并提供相关示例代码。 一、基础用法 使用Python的海龟库,我们可以控制一个小海龟在窗口中移动,并利用它的“画笔”在窗口中绘制…

    编程 2025-04-29
  • Python樱花树代码简单

    本文将对Python樱花树代码进行详细的阐述和讲解,帮助读者更好地理解该代码的实现方法。 一、简介 樱花树是一种图形效果,它的实现方法比较简单。Python中可以通过turtle这…

    编程 2025-04-28
  • Python大神作品:让编程变得更加简单

    Python作为一种高级的解释性编程语言,一直被广泛地运用于各个领域,从Web开发、游戏开发到人工智能,Python都扮演着重要的角色。Python的代码简洁明了,易于阅读和维护,…

    编程 2025-04-28
  • 用Python实现简单爬虫程序

    在当今时代,互联网上的信息量是爆炸式增长的,其中很多信息可以被利用。对于数据分析、数据挖掘或者其他一些需要大量数据的任务,我们可以使用爬虫技术从各个网站获取需要的信息。而Pytho…

    编程 2025-04-28
  • 如何制作一个简单的换装游戏

    本文将从以下几个方面,为大家介绍如何制作一个简单的换装游戏: 1. 游戏需求和界面设计 2. 使用HTML、CSS和JavaScript开发游戏 3. 实现游戏的基本功能:拖拽交互…

    编程 2025-04-27
  • Guava Limiter——限流器的简单易用

    本文将从多个维度对Guava Limiter进行详细阐述,介绍其定义、使用方法、工作原理和案例应用等方面,并给出完整的代码示例,希望能够帮助读者更好地了解和使用该库。 一、定义 G…

    编程 2025-04-27
  • 2的32次方-1:一个看似简单却又复杂的数字

    对于计算机领域的人来说,2的32次方-1(也就是十进制下的4294967295)这个数字并不陌生。它经常被用来表示IPv4地址或者无符号32位整数的最大值。但实际上,这个数字却包含…

    编程 2025-04-27
  • 制作一个简单的管理系统的成本及实现

    想要制作一个简单的管理系统,需要进行技术选型、开发、测试等过程,那么这个过程会花费多少钱呢?我们将从多个方面来阐述制作一个简单的管理系统的成本及实现。 一、技术选型 当我们开始思考…

    编程 2025-04-27

发表回复

登录后才能评论