ios mysql 修改数据,iOS数据库FMDB--增删改查(模糊查询)实写记录

本文介绍了iOS中SQLite数据库作为数据缓存的主要方式,阐述了系统存储方式的弊端,并详细讲解了SQLite的创建、操作及FMDB这个第三方库的使用。内容包括数据库单例创建、表的创建与操作、数据的增删改查等,强调了操作时的注意事项,如数据类型的匹配、查询语句的编写等。
摘要由CSDN通过智能技术生成

在iOS中,主要有5种数据缓存的策略:

1、plist

2、归档

3、偏好设置

4、沙盒文件

5、"SQLite数据库"

其中,"SQLite数据库" 是最常用的数据缓存方式,在开发中,在无网络的状态下,数据库常常发挥着非常大的作用!

系统提供的数据存储方式的弊端 :

1)不方便操作大量的数据

- 系统提供的数据存储方式都是覆盖存储的,新的数据会覆盖旧的数据.而且当数据量非常大时,如果要添加新的数据,必须先把旧数据全部加载到内存中

2)不方便查找大量的数据

- 当数据量非常庞大时,要查询其中某些数据,就非常困难。

而数据库可以轻松解决以上弊端~

存储方式:(类比于Excel表格)

"Excel"                                           "SQLite"

- 创建Excel文件                   - 创建一个数据库文件

- 创建表                                - 创建表

- 确定表头                            - 创建数据库的字段名(Excel表头),并指定数据类型

- 对Excel表进行数据操作    - 对数据库进行增删改查

FMDB的使用流程:

简单介绍:FMDB 是一个操作数据库的第三方框架,并且支持多线程环境下的操作,也是需要手动导入'libsqlite3.0.tbd'库,以OC的方式封装了SQLite的C语言API。方便灵活并且线程安全。

"FMDatabase" : 单线程;"FMDatabaseQueue" : 多线程;"FMResultSet" : 查询的结果集。

1、创建数据库单例对象(一个数据库可以存在多个表)

2、创建数据库储存路径

3、创建表

4、对表格进行增删改查等操作

上代码:

1、创建数据库单例对象,如图1

135498f005db

图1

注意:创建单例的原因是保证数据库队列只创建一次,全局只有一个串行队列,这样操作数据更安全。

2、创建数据库路径和表格,如图 2

135498f005db

图2

解析:单引号‘’中为表格的字段名,逗号后面为字段所属类型,字段类型是整形就用interger,字符串就用text。

注意:主键要想实现自动增长,不能是text类型。

3、进行数据库操作 ---增删改查

提示:建表,增删改 操作都是方法 "[_db executeUpdate]"或者"[_db executeStatements]",查询是另外的方法 "[_db executeQuery]"  。星号(*)是选取所有列的快捷方式。SQL 语句对大小写不敏感。SELECT 等效于 select。

1 ) INSERT INTO

INSERT INTO 语句用于向表格中插入新的行。

语法:INSERT INTO 表名称 VALUES (值1, 值2,....)

也可以向指定的列插入数据:INSERT INTO table_name (列1, 列2,...) VALUES (值1, 值2,....)

将数据写入表格,如图3

135498f005db

图3

135498f005db

图4

注意:在写入数据时候注意先判断是否存在!如图4

注意!请注意:

1)列名称和值名称的顺序要一一对应!例如:列名banner要对应自己的类型text。

2)如果列名类型是NSString,则需要加单引号 ‘’ 括住,例如:'%@',只应用于字符串类型。

3)对数据库进行操作增删改查之前要先打开数据库,操作完毕要关闭数据库。这只是一种严谨的写法,最好这样,否则可能会操作失败。

2)DELETE

DELETE 语句用于删除表中的行。

语法:DELETE FROM 表名称 WHERE 列名称 = 值,删除所有行:DELETE FROM 表名 或者DELETE * FROM 表名。

现在我们删除itemid为Shoe0101、Shoe0102这两行~  如图5

135498f005db

图5

3)UPDATE

Update 语句用于修改表中的数据。

语法:更新某行的一列:UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值。更新某行的若干列:UPDATE 表名称 SET 列名称1 = 新值1 ,列名称2 = 新值2 WHERE 列名称 = 某值。

将idNew为10000103的那一行 name改为静林是真的瓜子,status改为U,看代码:如图 6。

135498f005db

图6

4)SELECT

SELECT 语句用于从表中选取数据。结果被存储在一个结果表中(称为结果集)。

语法:SELECT 列名称 FROM 表名称 或者 SELECT * FROM 表名称。

再次提示:星号(*)是选取所有列的快捷方式。SQL 语句对大小写不敏感。SELECT 等效于 select。

在讲update的时候已经写了一些select的语句了。通过条件查询 如图7

135498f005db

图7

注意:获取结果集列顺序的时候,一定要取对类型,比如banner类型是字符串就要用stringForColumnIndex,整形就要使用intForColumnIndex,长整型就要使用longForColumnIndex,类型取不对,会导致返回的结果不对,切记!

通过关键字查询结果,如图8:

135498f005db

图8

大坑注意:

1)模糊查询时,需要自己拼接查询语句,不要使用框架提供的

2)'%' 是特殊字符,此时需要使用%转义.即 '%%'

3)自己拼接查询语句时,就需要自己添加单引号把字符串引起来

错误的拼接和执行模糊查询的方式:FMResultSet *resultSet = [_db executeQueryWithFormat:@"select * from t_heros where name like '%%%@%%'",keyWord];

正确的拼接和执行模糊查询的方式:NSString *selectSQL = [NSString stringWithFormat:@"select * from t_heros where name like '%%%@%%'",keyWord];

FMResultSet *resultSet = [_db executeQuery:selectSQL];

到这里就写完啦~希望对你有所帮助!不足之处敬请谅解并希望加以指正!

case R.id.btn_add: String msg_add = ed_msg.getText().toString(); User user_add = new User(msg_add, null); UserDao userDao_add = new UserDao(user_add, act); if (userDao_add.add() > 0) { Toast.makeText(act.getApplicationContext(), "添加成功", Toast.LENGTH_LONG).show(); } break; case R.id.btn_check: User user_check = new User(null, null); UserDao userDao_check = new UserDao(user_check, act); Cursor cursor = userDao_check.select(); String str = ""; if (cursor.moveToFirst()) { do { int d = cursor.getColumnIndex(MyDatabase.KEY_ID); String id = cursor.getString(d); int columnIndex = cursor .getColumnIndex(MyDatabase.KEY_NAME); String s = cursor.getString(columnIndex); str = str + id + "\t" + s + "\n"; } while (cursor.moveToNext()); tv_msg.setText(str); } break; case R.id.btn_amend: String msg_update = ed_msg.getText().toString(); String id = ed_id.getText().toString(); if (msg_update.equals("")) { Toast.makeText(act, "ID不能为空", Toast.LENGTH_LONG).show(); return; } User user_update = new User(msg_update, id); // int id_update = Integer.parseInt(id); UserDao userDao_update = new UserDao(user_update, act); if (userDao_update.updata() > 0) { Toast.makeText(act.getApplicationContext(), "修改成功", Toast.LENGTH_LONG).show(); } break; case R.id.btn_delete: String id_delete = ed_id.getText().toString(); User user_delete = new User(null, id_delete); if (id_delete.equals("")) { Toast.makeText(act, "ID不能为空", Toast.LENGTH_LONG).show(); return; } UserDao userDao_delete = new UserDao(user_delete, act); if (userDao_delete.delete() > 0) { Toast.makeText(act.getApplicationContext(), "删除成功", Toast.LENGTH_LONG).show(); } ;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值