【iOS10】使用XCode8、Swift3. 操作SQLite3数据库的步骤(包括配置环境和SQLite语句)

一、配置使用SQLite时的Swift框架工程环境

步骤如下:

1、点击项目名称 – Linked Frameworks and Libraries – “+” – 搜索“libsqlite3.dylib” – 然后点击Add

snip20161202_59

snip20161202_62

【访问SQLite数据库需要使用SQLite官方提供的C语言风格的API,所以需要添加桥接文件】

2、右击项目名称 – New File… – Header File – 命名为“SQLite-Bridge.h”,并在“SQLite-Bridge.h”这个头文件中加一行代码#import "sqlite.h"

snip20161202_63

3、点击项目名称 – Build Settings – 点击All – 点击Combined – 搜索“bridging” – 单击“Objective-C Bridging Header” – 双击后面后弹出添加文件名,把刚刚创建的头文件名称写进去- 然后回车

snip20161202_72

这时候配置工作就算完成了,就可以在项目里面写或者导入数据库操作方面(比如创建数据库)的代码文件了~

  • 小提示:如果出现了找不到模块的错误,并且有如下报错:
    • Unsupported architecture
    • ‘arm/arch.h’file not found
    • Could not build module ‘Darwin’
    • Could not build module ‘sqlite3’
    • Failed to import bridging header ‘…..’
  • snip20161202_80

在自己编写的SQLiteManager文件里面不需要写import sqlite3这句话。。直接使用SQLite语句就行了

 

二、通过一个demo展现数据库操作的功能的实现

制作一个demo,使用swift3、Xcode8、iOS10

该demo的功能如下:

共有两个页面,第一个页面(主页)是个tableview,用来展现查找得到的数据,第二个页面(添加页)是学号和姓名的添加文本框。通过在第二个页面的添加学生的学号和姓名,并且将修改后的数据重新加载在第一个tableview页面。tableview的页面支持delete某一条记录。

Demo的截图如下:

snip20161203_83 snip20161203_84

demo的源代码已上传至github:https://github.com/liuchuo/SQLite-Demo-With-Swift

三、demo的代码中的SQLManager.swift中的代码:

【iOS】Swift3 报错:Value of type ‘AppDelegate’ has no member ‘managedObjectContext’,UIApplication has no member ‘sharedApplication’

在Swift 3里面,需要通过viewContext访问managedObjectContext,且sharedApplication方法改为shared方法:

以前是这样写的:

Swift代码规范

  •  一行不要超过160个字符
  • 左大括号不换行
  • 运算符( + – * / == != ->)左右加空格,

  • 逗号、冒号的后面加空格,但遇到后面是小括号则不需要加空格

  • if else的else、do catch的catch,与大括号在同一行

  • 跨多行函数声明要缩进

  • 跨多行if语句要缩进

  • 尽量避免多行断言,可以使用本地变量或者其他策略

  • 尽可能多使用let,少使用var
  • 如果变量类型可以依靠推断得出,不建议声明变量时指名类型
  • switch模块中不用显式使用break
  • if语句左右不要使用小括号

  • 不要使用as! 或 try!
  • 在解析可选类型时,推荐使用 guard 语句,而不是 if 语句,因为 guard 语句可以减少不必要的嵌套缩进
  • 如果需要在2个状态间做出选择,建议使用if 语句,而不是使用 guard 语句
  • 即使文档注释只有一行,也要使用模块化格式 (/** */)
  • 使用首字母大写的驼峰命名规则来命名枚举值

  • 尽可能的避免使用强制转换和强制解包
  • 不要在 if 和 switch 条件两边或者 return 关键词上加 Objective-C 样式的圆括号
  • 避免使用行尾分号,尽管这样是可以编译通过的。但是它们会让你的代码看起来很糟糕,而且用起来体验也很差。
  • 版权声明应该被包含在所有源文件的顶部
  • 笑脸

  • 用足够的空行把代码分割成合理的块
  • 不要在一行结尾留下空白,也不要在空行留下缩进
  • 文件结束时留一空行