【问题标题】:How to insert an image into sqlite database?如何将图像插入 sqlite 数据库?
【发布时间】:2011-07-22 01:14:44
【问题描述】:

我已经尝试了以下代码:

1.将位图转换为字节数组的代码:

private byte[] bitmaptoByteArray( Bitmap bmp)
      {
          ByteArrayOutputStream stream = new ByteArrayOutputStream();
          bmp.compress(Bitmap.CompressFormat.PNG, 100, stream);
          byte[] byteArray = stream.toByteArray();
          return byteArray;
      }

2.将值插入数据库的代码

  public void insertIntoImageTable( int companyid , String productname , String productdesc , byte[] bmp )
      {
          ContentValues values = new ContentValues();
            values.put(dataBaseHelper.COMPANY_ID, companyid);           
            values.put(dataBaseHelper.PRODUCT_NAME, productname);
            values.put(dataBaseHelper.PRODUCT_DESCRIPTION, productdesc);
            values.put(dataBaseHelper.PRODUCT_IMAGE, bmp);
            try
            {
                db.insert(dataBaseHelper.IMAGE_DATA, null, values);
            }
            catch( Exception e)
            {
                e.printStackTrace();
            }
      }

我得到空指针异常。

从函数调用将数据放入数据库:

   insertIntoImageTable( 7 , productname[0] , productdesc[0] , barry);

这三位代码都在同一个类文件中。

编辑:堆栈跟踪如下。

03-24 16:04:26.245: WARN/System.err(13255): java.lang.NullPointerException
03-24 16:04:26.265: WARN/System.err(13255):     at com.omkarsoft.ImagePortofolio.sqlQueries.insertIntoImageTable(sqlQueries.java:101)
03-24 16:04:26.275: WARN/System.err(13255):     at com.omkarsoft.ImagePortofolio.sqlQueries.upLoadtoDatabase(sqlQueries.java:118)
03-24 16:04:26.305: WARN/System.err(13255):     at com.omkarsoft.ImagePortofolio.ImageAdapter.<init>(ImageAdapter.java:58)
03-24 16:04:26.315: WARN/System.err(13255):     at com.omkarsoft.ImagePortofolio.imageGridView.onCreate(imageGridView.java:42)
03-24 16:04:26.335: WARN/System.err(13255):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
03-24 16:04:26.335: WARN/System.err(13255):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
03-24 16:04:26.355: WARN/System.err(13255):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
03-24 16:04:26.385: WARN/System.err(13255):     at android.app.ActivityThread.access$1500(ActivityThread.java:117)
03-24 16:04:26.385: WARN/System.err(13255):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
03-24 16:04:26.415: WARN/System.err(13255):     at android.os.Handler.dispatchMessage(Handler.java:99)
03-24 16:04:26.415: WARN/System.err(13255):     at android.os.Looper.loop(Looper.java:123)
03-24 16:04:26.435: WARN/System.err(13255):     at android.app.ActivityThread.main(ActivityThread.java:3683)
03-24 16:04:26.445: WARN/System.err(13255):     at java.lang.reflect.Method.invokeNative(Native Method)
03-24 16:04:26.455: WARN/System.err(13255):     at java.lang.reflect.Method.invoke(Method.java:507)
03-24 16:04:26.475: WARN/System.err(13255):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
03-24 16:04:26.475: WARN/System.err(13255):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
03-24 16:04:26.505: WARN/System.err(13255):     at dalvik.system.NativeStart.main(Native Method)

【问题讨论】:

  • 请显示异常。每次你有一个时都这样做。
  • 看来你的数据库变量为空。
  • 空指针异常
  • 这个,db.insert(dataBaseHelper.IMAGE_DATA, null, values);
  • Base64 编码您的图像并将其存储为文本。它使工作变得更加容易。

标签: android image sqlite


【解决方案1】:

您的数据库似乎为空或productname[0],productdesc[0]orbarry` 为空。

一般来说,在 Android 上保存大文件时,应该将文件保存到磁盘(如果有的话,可能是 SD 卡),然后将文件 URI 存储在数据库中。 Android 上的 SQLite 数据库并不是真正为存储大型内容而设计的 - 直接存储大型文件会提高性能。

【讨论】:

    【解决方案2】:

    您是否实例化了您的 dataBaseHelper 并检查了数据库是否已创建?

    您在 sqlQueries.java 类第 101 行收到 NullPointerException

    【讨论】:

    • 是的,在这一行中,values.put(dataBaseHelper.COMPANY_ID, companyid); dataBaseHelper 是类的实例
    【解决方案3】:

    你初始化你的数据库了吗?

    db.insert(dataBaseHelper.IMAGE_DATA, null, values);

    【讨论】:

      猜你喜欢
      • 2021-09-13
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2023-02-07
      • 1970-01-01
      • 1970-01-01
      • 2011-07-16
      • 2017-05-15
      相关资源
      最近更新 更多