将json数据添加到数据库

本文介绍了一个使用SQLiteOpenHelper创建数据库并实现数据增删查改功能的示例。具体包括数据库的创建过程、数据表结构定义、数据插入及更新方法、以及如何通过URL查询特定JSON数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/////创建数据库:

public class MyHelper extends SQLiteOpenHelper {
public MyHelper(Context context) {
    super(context, "dataa.db", null, 1);
}

@Override
public void onCreate(SQLiteDatabase sqLiteDatabase) {
    //创建表
    sqLiteDatabase.execSQL("create table jsoncache(id integer primary key autoincrement,json text not null,url text not null)");

}

@Override
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {

}
}

////dao方法里:

public class JsonDao {

private MyHelper myHelper;

public JsonDao(Context context) {

    myHelper = new MyHelper(context);
}

/**
 * 插入数据的操作
 */
public void insertJson(String json,String url){

    SQLiteDatabase database = myHelper.getWritableDatabase();
    //现根据url删除json
    database.delete("jsoncache","url = ?",new String[]{url});

    //再去添加
    ContentValues values = new ContentValues();
    values.put("json",json);
    values.put("url",url);

    database.insert("jsoncache",null,values);

    //关闭
    database.close();
}


/**
 * 查询数据库的操作....根据传入url获取存的json字符串
 */
public String getJson(String url){

    SQLiteDatabase writableDatabase = myHelper.getWritableDatabase();

    Cursor cursor = writableDatabase.query("jsoncache", new String[]{"json"}, "url = ?", new String[]{url}, null, null, null);

    if (cursor.moveToNext()){
        String json = cursor.getString(cursor.getColumnIndex("json"));

        return json;
    }

    return null;
}

}

///如果使用时,直接添加到方法里:

jsonDao = new JsonDao(getContext());
    //1.先读取数据库中存的数据....有数据,解析展示....无数据,网络获取数据
    String json = jsonDao.getJson("http://gank.io/api/data/Android/10/" + page_num);
    if (json != null){
        //解析 显示

        Gson gson = new Gson();

        DataDataBean dataDataBean = gson.fromJson(json, DataDataBean.class);

        //往后面添加...
        list.addAll(dataDataBean.getResults());

        //设置适配器
        setAdapter();

    }else {
        //1.设置listView的适配器
        getDataFromNet();
    }
要将 JSON 数据添加到 MySQL 数据库,你可以按照以下步骤进行操作: 1. 首先,确保你已经在 Java 项目中引入了 JSON 库,例如 Gson、Jackson 或者 JSON-Simple。你可以通过在 `pom.xml`(如果使用 Maven)或者通过下载并添加 JAR 文件来完成这一步骤。 2. 创建一个 Java 类来表示你要添加数据库数据。这个类应该具有与数据库表中的列对应的属性。 ```java public class MyClass { private int id; private String name; // 构造函数、getter 和 setter 方法 } ``` 3. 在 Java 代码中,使用 `java.sql.Connection` 接口来连接到 MySQL 数据库。你需要提供数据库的 URL、用户名和密码。 ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; public class MySQLConnection { private static final String URL = "jdbc:mysql://localhost:3306/database_name"; private static final String USERNAME = "your_username"; private static final String PASSWORD = "your_password"; public static Connection getConnection() throws SQLException { return DriverManager.getConnection(URL, USERNAME, PASSWORD); } } ``` 确保将 `database_name` 替换为你要连接的数据库的名称,并将 `your_username` 和 `your_password` 替换为数据库的用户名和密码。 4. 编写一个方法来将 JSON 数据解析为 Java 对象,并将其添加数据库中。 ```java import com.google.gson.Gson; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.SQLException; public class MyClassDAO { public void addMyClassFromJson(String json) { Gson gson = new Gson(); MyClass myClass = gson.fromJson(json, MyClass.class); try (Connection connection = MySQLConnection.getConnection()) { String query = "INSERT INTO my_table (id, name) VALUES (?, ?)"; PreparedStatement statement = connection.prepareStatement(query); statement.setInt(1, myClass.getId()); statement.setString(2, myClass.getName()); statement.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } } } ``` 确保将 `my_table` 替换为你要将数据添加到的数据库表的名称。 现在,你可以在其他地方创建一个包含 JSON 数据的字符串,并使用 `MyClassDAO` 类的 `addMyClassFromJson()` 方法将其添加到 MySQL 数据库中。 请注意,这只是一个简单的示例,你可能需要根据你的实际需求进行修改和扩展。另外,确保在将 JSON 数据解析为 Java 对象之前,对 JSON 数据进行验证和处理以确保其有效性和完整性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值