Android上的SQLite如何处理长字符串?

时间:2010-06-18 08:36:49

标签: android sqlite

我想知道Android的SQLite实现如何处理长字符串。从sqlite的在线文档中读到,它说sqlite中的字符串限制为100万个字符。我的琴弦肯定更小。

我正在创建一个简单的RSS应用程序,在解析html文档并提取文本后,我遇到了将其保存到数据库的问题。我在数据库中有2个表,feedsarticles。从feeds表正确保存和检索RSS提要,但在保存到articles表时,logcat表示无法将提取的文本保存到其列中。我不知道其他列是否也有问题,在logcat中没有提到它们。

我想知道,因为文字是来自网上的一篇文章,是否有类似(“,',;)等问题会产生问题?Android会自动逃避它们吗,或者我必须这样做。我正在使用一种技术插入类似于记事本教程中的一个:

public long insertArticle(long feedid, String title, String link, String description, String h1,tring h2, String h3, String p, String image, long date) {
    ContentValues initialValues = new ContentValues();
    initialValues.put(KEY_FEEDID, feedid);
    initialValues.put(KEY_TITLE, title);
    initialValues.put(KEY_LINK, link);
    initialValues.put(KEY_DESCRIPTION, description );
    initialValues.put(KEY_H1, h1 );
    initialValues.put(KEY_H2, h2);
    initialValues.put(KEY_H3, h3);
    initialValues.put(KEY_P, p);
    initialValues.put(KEY_IMAGE, image);
    initialValues.put(KEY_DATE, date);
    return mDb.insert(DATABASE_TABLE_ARTICLES,null, initialValues);
}

P列用于提取文本,h1,h2和h3用于页面的标题。 Logcat仅报告列p是问题。该表使用以下语句创建:

private static final String DATABASE_CREATE_ARTICLES =
    "create table articles( _id integer primary key autoincrement, feedid integer, title text, link text not null, description text," + "h1 text, h2 text, h3 text, p text, image text, date integer);";

1 个答案:

答案 0 :(得分:7)

由于Android使用SQLite作为后端,因此所有字段都是可变长度的。默认的sqlite字段长度限制是10亿个字符,但android可能已经改变了这个。