Podfile文件:
platform :ios, "7.0"
pod 'FMDB'
pod 'FMDBMigrationManager'
使用pod install
命令安装
FMDBMigrationManager *manager = [FMDBMigrationManager managerWithDatabaseAtPath:[YMDatabaseHelper databasePath] migrationsBundle:[NSBundle mainBundle]];
其中[YMDatabaseHelper databasePath]
是数据库路径
BOOL resultState = [manager createMigrationsTable:&error];
创建的迁移表名称为:schema_migrations
该文件用来存储每次升级使用的SQL语句。
FMDBMigrationManager建议我们使用时间戳来作为版本号,使用下面的命令生成一个文件:
touch "`ruby -e "puts Time.now.strftime('%Y%m%d%H%M%S%3N').to_i"`"_CreateMyAwesomeTable.sql
我生成的文件名为:20150420170044940_CreateMyAwesomeTable.sql
,其中20150420170044940为迁移的版本号标识。
我们在 20150420170044940_CreateMyAwesomeTable.sql
文件中创建一个用户表,写入:
CREATE TABLE User( id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT, name TEXT );
FMDBMigrationManager *manager = [FMDBMigrationManager managerWithDatabaseAtPath:[YMDatabaseHelper databasePath] migrationsBundle:[NSBundle mainBundle]];
BOOL resultState = NO;
NSError *error = nil;
if (!manager.hasMigrationsTable) {
resultState = [manager createMigrationsTable:&error];
}
resultState = [manager migrateDatabaseToVersion:UINT64_MAX progress:nil error:&error];//迁移函数
NSLog(@"Has `schema_migrations` table?: %@", manager.hasMigrationsTable ? @"YES" : @"NO");
NSLog(@"Origin Version: %llu", manager.originVersion);
NSLog(@"Current version: %llu", manager.currentVersion);
NSLog(@"All migrations: %@", manager.migrations);
NSLog(@"Applied versions: %@", manager.appliedVersions);
NSLog(@"Pending versions: %@", manager.pendingVersions);
运行项目,打印出如下内容:
2015-04-20 20:50:19.033 YMFMDatabase[12654:1326201] Has schema_migrations
table?: YES
2015-04-20 20:50:19.036 YMFMDatabase[12654:1326201] Origin Version: 20150420170044940
2015-04-20 20:50:19.036 YMFMDatabase[12654:1326201] Current version: 20150420170044940
2015-04-20 20:50:19.037 YMFMDatabase[12654:1326201] All migrations: (
"<FMDBFileMigration: 0x17003b4c0>"
)
2015-04-20 20:50:19.037 YMFMDatabase[12654:1326201] Applied versions: (
20150420170044940
)
2015-04-20 20:50:19.038 YMFMDatabase[12654:1326201] Pending versions: (
)
用iFunBox查看下是不是创建了一个User表,里面含有id、name字段。以及FMDBMigrationManager生成的schema_migrations表。
##5.创建第二个.sql文件
先用上方命令:``touch "`ruby -e "puts Time.now.strftime('%Y%m%d%H%M%S%3N').to_i"`"_CreateMyAwesomeTable.sql``生成,我生成的是:20150420170557221_CreateMyAwesomeTable.sql。
第二个sql文件,里面创建一个新表名字为Grouping,为原先的User表添加邮箱字段:email。.sql文件修改如下:
CREATE TABLE Grouping(
id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
name TEXT
);
ALTER TABLE User ADD email TEXT;
##6.创建第三个.sql文件
生成同上,文件内容是为Grouping表添加备注字段remark:
文件内容:
ALTER TABLE Grouping ADD remark TEXT;
```
OK,直接运行项目,看看是不是创建了Grouping表,里面含有id,name,remark字段,以及User表里面是不是添加了email字段。
中间我自己做Demo时,试图删除表中的某列,比如删除User中的name列,但是不能成功,Google了下发现答案。
>
SQLite supports a limited subset of ALTER TABLE. The ALTER TABLE command in SQLite allows the user to rename a table or to add a new column to an existing table. It is not possible to rename a column, remove a column, or add or remove constraints from a table.
解释下:就是说SQLite对ALERT TABLE命令受限制,SQLite 中的 ALERT TABLE命令只能允许用户重命名表或者添加新列,不能重命名列或者删除列或者删除约束。