行太大,无法放入光标窗口

Sha*_*awn 5 sql android

我正在存储一个 PNG 文件,该文件被转换为位图,该位图被转换为 Byte[] 并存储 MySQL 数据库。

当我尝试调用数据库中的项目时,出现以下错误。

E/SQLiteQuery:异常:行太大,无法放入 CursorWindow requiredPos=0,totalRows=1;查询:SELECT * FROM myTable

引起原因:android.database.sqlite.SQLiteBlobTooBigException:行太大,无法放入 CursorWindow requiredPos=0,totalRows=1

有没有办法增加光标窗口的大小以接受 byte[]?

@Dao
public interface MyDAO {

    @Query("SELECT * FROM myTable")
    LiveData<List<MyEntity>>getAllImages();
Run Code Online (Sandbox Code Playgroud)
public class MyRepository {

    private MyDAO mMyDao;
    private LiveData<List<MyEntity>> mList;

    public MyRepository(Application application) {
        MyDatabase db = MyDatabase.getInstance(application);
        this.mMyDao = db.mMyDao();
        mList = mMyDao.getAllImages();
    }

    public LiveData<List<MyEntity>> getAllImages(){
        return mList;
    }

Run Code Online (Sandbox Code Playgroud)
import java.util.List;

public class MainViewModel extends AndroidViewModel {

    private MyRepository mRepository;
    private LiveData<List<MyEntity>> mList;

    public MainViewModel(Application application) {
        super(application);
        mRepository = new MyRepository(application);
        mList = mRepository.getAllImages();
    }

    public LiveData<List<MyEntity>> getList() {
        return mList;
    }
Run Code Online (Sandbox Code Playgroud)
public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        final MainViewModel myViewModel = ViewModelProviders.of(this).get(MainViewModel.class);


        Button btnLog = findViewById(R.id.btn_log);
        btnLog.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Log.d("MyLog", "update Log");
                myViewModel.getList().observe(MainActivity.this, new Observer<List<MyEntity>>() {
                    @Override
                    public void onChanged(List<MyEntity> myEntities) {

                        int listSize = myEntities.size();
                        Log.d("MyLog", "LiseSize " + listSize);
                        for(int i = 0; i < listSize; i++) {
                            Log.d("MyLog", "MyID " + myEntities.get(i).getID() +
                                    ", bitmap " + myEntities.get(i).getPHOTO());
                        }
                    }
                });
            }
        });
Run Code Online (Sandbox Code Playgroud)

我期待在 log cat 中看到 byte[]