SQLite入门之sql写法(二)
2017-05-29 19:29
183 查看
连接数据库
1.连接数据库具体方法如下(创建连接类必须继承SQLiteOpenHelper类)按截图进行操作即可:增删改查的写法
1.增加场景描述:在文件夹下添加txt文件,命名为text.text.在文档中输入
AB.中国内容.
在增加数据方法中,编写以下代码:如图所示:
Inputstream in = this.getContext().getResources().getAssets().open("txt.txt"); int length = in.available(); byte[] b = new byte[length]; in.read(b); db.execSQL("insert into person (name,salary,pic) values (?,?,?)",new Object[]{"admin",100.00,b});
2.修改
db.execSQL(" update person set salary = ? where id = ? ",new Object[]{100.00,1});
3.查询
Cursor cursor =db.rawQuery("select * from person limit ?,? ",new string[]{"0","2"}); cursor类似如java中的resultset,方便理解。 while(cursor.moveToNext()){ //第一种方法通过索引获取数据,此方法可读性差 int id = cursor.getInt(0); //第二种方法通过列名获取索引,在有索引获取数据 String name = cursor.getString(cursor.getColumnIndex("name")); }
截图如下:
文件编码、数据库编码、获取文件编码必须一致。
//查询当前数据库编码(sql语句):
PRAGMA encoding;
//检查assets文件夹下的文件内容编码是否和数据库编码一致
//设置查询时候,文件的编码更改new string(b) 为new string(b,’utf-8’);
4.删除
db.execSQL("delete from person where _id = ? ",new Object[]{1});
默认采用纯sql方式进行数据的操作:
1.缺点:sql语句需要手写,容易出错,在更新操作没有返回的行数
2.Android内容提供者(读取短信,通讯录),默认不支持纯sql语句读取而是支持api的方式。
使用api进行数据库操作:
1.新增数据
2.删除数据
db.delete(“表名”,”参数”,”值”);
int result =db.delete("person","_id=? and name = ? ",new String[]{"1","admin"});
3.更新数据
4.事务
上述事务中,因10/0异常直接执行finally回滚事务,删除语句执行回滚则没有删除该条数据。
在前端显示图片的时候需要通过下列方式进行对byte[]数组进行转换,如下图所示:
通过游标获取数据库中的btye数据,通过BitmapFactory工厂进行转换。
相关文章推荐
- 关于动态SQL的写法
- mysql中获取一小时、一天、一周、一月时间数据的各种sql语句写法
- 两种删除去重复记录的sql写法
- SQL快速入门 ( MySQL快速入门, MySQL参考, MySQL快速回顾 )
- 取一表前N条记录,各个数据库的SQL写法
- SQLite快速入门指南
- Android SQLite快速入门教程
- SQLite 入门教程(二)创建、修改、删除表
- MS SQL入门基础:Transact-SQL 语言概述
- MS SQL入门基础:sql 其它命令
- MySQL入门基本命令 SQL分类,DDL,DML
- MySQL查询不区分大小写的sql写法
- SQLite 入门教程(一)基本控制台(终端)命令
- SQL各种写法的效率问题
- SQLite 入门教程二 SQLite的创建、修改、删除表
- c#中SQL语句参数标准写法
- 投票类型相关sql语句的写法
- MySQL基础入门—SQL介绍及MySQL的安装
- SQLite入门与分析(二)---设计与概念(续)
- sqlite入门基础(一):sqlite3_open,sqlite3_exec,slite3_close