大佬教程收集整理的这篇文章主要介绍了android – SQLite – 是否可以通过insert语句插入BLOB?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
public class DatabaseHelper extends sqliteOpenHelper { ... DatabaseHelper(Context context,String nameOfDB,int version,String[] scriptsqlCreate,String scriptsqlDelete) { super(context,nameOfDB,null,version); this.scriptsqlCreate = scriptsqlCreate; this.scriptsqldelete = scriptsqldelete; } @Override public void onCreate(sqliteDatabase db) { int numScripts = scriptsqlCreate.length; for(int i = 0; i<numScripts; i++){ Log.i(tag,"CreaTing database,execuTing script " + i); db.execsql(scriptsqlCreate[i]); } } }
…
我想传递一个常量到上面显示的scriptsqlCreate参数,就像这样:
private static final String[] SCRIPT_DATABASE_CREATE = { "create table memes( id INTEGER PRIMary key autoincrement," + + " img blob not null," + + " @R_548_4687@t not null uniquE)","insert into memes(img,Name) values(BITMAP1,'1.jpg')",Name) values(BITMAP2,'2.jpg')",Name) values(BITMAP3,'3.jpg')"} }
任何帮助将会很多,
谢谢,
Tulio Zahn
insert into memes(img,Name) values(X'0102030405060708090a0b0c0d0e0f','1.jpg')
但是,这通常是一个坏主意;相反,请看看parameterised queries.他们将让您编写一次使用占位符而不是实际值的语句,然后重复使用多次,根据需要填写占位符:
sqliteStatement p = sqlite.compileStatement("insert into memes(img,Name) values(?,?)"); byte[] data = loadData("1.jpg"); p.bindBlob(1,data); p.bindString(2,"1.jpg"); p.execute(); byte[] data = loadData("2.jpg"); p.bindBlob(1,"2.jpg"); p.execute();
(警告—代码未测试.)
一般来说,您应该在任何地方使用参数化查询,因为它们是一种可靠的方式来避免sql注入攻击,另外通常更容易和更清晰.应该不惜一切代价避免将字符串混合在一起来组合SQL查询.
以上是大佬教程为你收集整理的android – SQLite – 是否可以通过insert语句插入BLOB?全部内容,希望文章能够帮你解决android – SQLite – 是否可以通过insert语句插入BLOB?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。