ios 查询mysql数据库操作系统_iOS数据库FMDB--增删改查(模糊查询)详细介绍

简介:

很早就想整理一下数据库的使用了,刚好最近接触较多,加之可以安排出空余的时间,所以瓜子我贡献出自己喝咖啡的时间整理一下FMDB的使用,以下是对FMDB的介绍以及基本使用 --- insert、delete、update、select。其中select讲了两种比较重要的方式---ID查询、模糊查询。

在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

1dd4e687f146

图 1

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

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

1dd4e687f146

1dd4e687f146

图 2

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

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

我们看到,在沙盒中已经建好了表名为:JLcharacterModel 的数据库。如图3

1dd4e687f146

图 3

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,....)

将数据写入表格,如图4(以下数据来源于卓浦士科技所属的app ---足球技能分析大师TropsX的云端数据,因为安全问题,将部分信息遮挡,敬请谅解)

1dd4e687f146

图 4

注意!请注意:

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

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

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

打开app本地数据库查看我们创建好的表格,如图 5

1dd4e687f146

图 5

这时候你会发现,表格是空的!!!!!what ?

仔细一看,原来是创建表格的表名称写错了!!把 CharaterModel 改为 JLCharaterModel ,so,数据库路径的表名称跟插入数据写的表名称一定要相同!运行程序。铛铛铛~

1dd4e687f146

图 6

注释:图 6 信息显示不全。

2)DELETE

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

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

现在我们删除itemid为Shoe0101、Shoe0102这两行~ 代码如图 7。

1dd4e687f146

图 7

来看看数据库是否已经删除成功,如图8:铛铛铛~

1dd4e687f146

图 8

已经删除成功~

3)UPDATE

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

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

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

1dd4e687f146

图 9

图10 看看更新成功了没有?

1dd4e687f146

图 10

到这里就非常完美了~~

4)SELECT

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

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

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

在讲update的时候已经写了一些select的语句了。通过条件查询,图 11看代码~

1dd4e687f146

图 11

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

查询itemid为Shoe0103的结果,通过断点,我们可以知道返回了一个带有属性的model,如图12:

1dd4e687f146

图 12

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

1dd4e687f146

1dd4e687f146

图 13

我们查询列名name有“瓜子”、expiredays == 90的结果,如图14:

1dd4e687f146

图 14

可以看到得出一个结果~~

大坑注意:

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];

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/359824.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java arraylist 重复_Java中ArrayList去除重复元素

Java中ArrayList去除重复元素//删除ArrayList中重复元素public static void removeDuplicate(ArrayList list) {for ( int i 0 ; i for ( int j list.size() - 1 ; j > i; j -- ) {ForCytoLevel3 jjj (ForCytoLevel3)list.get(j);ForCytoLevel3 i…

c#时间转换

转自 http://blog.csdn.net/yysyangyangyangshan/article/details/6782874最近做ASP.NET的一个项目,获取时间的时候,由于我的系统时间设置了上午和下午,结果DateTime.Now老是写不到数据库中,然后,上网查了个[csharp]vi…

SQL Server 2008 R2如何生成带数据的数据库脚本

1.对想要复制的数据库右键,“任务”,“生成脚本” 2.下面需要注意的是,默认情况下,只会生成仅架构的脚本,也就是说仅仅有表结构,而没有数据的空壳。所以需要额外的设置。 在设置脚本编写选项,选…

java saxreader_JAVA解析XML,SAXReader无法使用

写了段代码要解析XML文件。for (int p 0; p < files.length; p) {System.out.println("Dom4jxml2:333::"p);if (files[p].isFile() && files[p].getName().startsWith("CN_MT1101_")) {File f new File(files[p].getPath());System.out.print…

methodhandle_概览Java 7 MethodHandle及其用法

methodhandle由于Java的Reflection API&#xff0c;我们已经能够在运行时检查和更改程序执行。 特别是&#xff0c;我们可以在运行时观察接口/类/方法和字段&#xff0c;而无需在编译时知道它们的名称。 JDK 7为这种动态/运行时检查引入了一个新的参与者&#xff0c;即方法句柄…

quartz CronExpression表达式

一个cron表达式有至少6个&#xff08;也可能7个&#xff09;有空格分隔的时间元素。按顺序依次为1.秒&#xff08;0~59&#xff09;2.分钟&#xff08;0~59&#xff09;3.小时&#xff08;0~23&#xff09;4.天&#xff08;月&#xff09;&#xff08;0~31&#xff0c;但是你需…

java两个字符串前缀_java – 找到两个字符串的最长公共前缀

我想找到两个字符串的最长公共前缀.有没有办法循环我的最后几个if语句,以便我可以结束彼此不匹配的最后几个字符&#xff1f;System.out.println("Enter the first string: ");String s input.nextLine();System.out.println("Enter the second string: "…

Codeforces 427 D. Match amp; Catch

后缀数组.... 在两个串中唯一出现的最小公共子串 D. Match & Catchtime limit per test1 secondmemory limit per test512 megabytesinputstandard inputoutputstandard outputPolice headquarter is monitoring signal on different frequency levels. They have got two …

gwt 同步和异步_GWT Spring和Hibernate进入数据网格世界

gwt 同步和异步利用Infinispan Data Grid的功能最大化Hibernate性能。 一个GWT &#xff0c; Spring &#xff0c; JPA &#xff0c; Hibernate &#xff0c; Infinispan集成教程。 在本教程中&#xff0c;我们将讨论如何将Infinispan用作Hibernate二级缓存提供程序。 Infinis…

java分页 jar_零基础学java之javaEE,分页

【分页】一 分页1.1分页概念引入什么是分页?分页(英语&#xff1a;Paging)&#xff0c;是一种操作系统里存储器管理的一种技术&#xff0c;可以使电脑的主存可以使用存储在辅助存储器中的数据。操作系统会将辅助存储器(通常是磁盘)中的数据分区成固定大小的区块&#xff0c;称…

查看修改MySQL字符集

查看修改MySQL字符集 http://blog.sina.com.cn/s/blog_70ac6bec01016fts.html 查看修改MySQL字符集 (2012-08-22 09:53:21) 转载▼标签&#xff1a; 字符集 mysql数据库 mysql字符集查看 mysql启动命令 修改mysql字符集 分类&#xff1a; 网站开发MySQL字符集多种多样…

java上传文件需要的依赖_SpringBoot使用commons-fileupload上传文件的类

网上找了一些&#xff0c;都是基本介绍&#xff0c;没有直接就可以使用类&#xff0c;在实际工作当中都有适合当前项目的上传文件的方法&#xff0c;本人写了一个类&#xff0c;比较基础&#xff0c;但呆以满足项目的上传文件功能&#xff0c;使用了commons-fileupload这个组件…

ArcGIS for Android示例解析之离线地图-----LocalTiledLayer

转自&#xff1a;http://blog.csdn.net/wozaifeiyang0/article/details/7327423 LocalTiledLayer 看到这个标题是否是很激动&#xff0c;如题&#xff0c;该示例就是添加一个离线地图&#xff0c;这应该是很多开发人员期盼已久的功能了吧&#xff0c;正式版一处这个应该是一个很…

md5 算法java实现_java实现MD5算法

import java.security.MessageDigest;/** 加密工具*author 刘彦青***/public class EncryptUtil {/** MD5加密** param jiami* 源字符串* return 加密后的字符串 */public final static String md5(String jiami) {char hexDigits[] { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C,…

wikioi 1017--乘积最大

给定一个数串&#xff0c;以及K&#xff0c;求对这个数串K划分的乘积最大值。 DP思路&#xff1a;一开始肯定想到的是递归&#xff0c;假设在某两个字符间有一个乘号&#xff0c;那么乘积最大就是乘号两边的区间接着划分的乘积最大值。 于是状态空间表示如下dp[i][k]表示从0~i之…

java在线找错_平台配置及测试错误提示及解决方案

平台配置错误提示及解决方案开发者在点击提交服务的时候可能会遇到以下各种各样的问题&#xff0c;本文列举出部分平台会弹出的提示&#xff0c;以便解决提交出现的问题。1、 请完成分发国家配置原因&#xff1a;未选择分发国家或未保存解决&#xff1a;在配置-发布国家中&…

d3 mysql_javascript – 在d3可视化中访问MySQL数据库

我需要一些关于d3和MySQL的帮助.以下是我的问题&#xff1a;我有数据存储在MySQL中(例如&#xff1a;关键字及其频率).我现在想用d3将其可视化.据我所知,d3需要json文件作为输入.我的问题是&#xff1a;如何从d3脚本访问这个MySQL数据库&#xff1f;我能想到的一种方法是&#…

resteasy_Tomcat 7上具有RESTeasy JAX-RS的RESTful Web服务– Eclipse和Maven项目

resteasy开发Web服务的RESTful方法不断受到越来越多的关注&#xff0c;并且似乎正在将SOAP淘汰。 我不会讨论哪种方法更好&#xff0c;但是我相信我们都同意REST更轻量级。 在本教程中&#xff0c;我将向您展示如何使用RESTeasy开发RESTful服务以及如何将它们部署在Tomcat服务器…

java httpserver 多个接口_多个Servlet之间数据共享实现方案

1.数据共享&#xff1a;OneServlet工作完毕后&#xff0c;将产生数据交给TwoServlet来使用Servlet规范中提供四种数据共享方案1.ServletContext接口2.Cookie类3.HttpSession接口4.HttpServletRequest接口ServletContext接口:1.介绍&#xff1a;1)来自于Servlet规范中一个接口。…

【Java心得总结六】Java容器中——Collection

在【Java心得总结五】Java容器上——容器初探这篇博文中&#xff0c;我对Java容器类库从一个整体的偏向于宏观的角度初步认识了Java容器类库。而在这篇博文中&#xff0c;我想着重对容器类库中的Collection容器做一个着重的探索与总结。 Collection&#xff1a;一个独立元素的序…