IOS学习之数据库(3)--SQL代码应用示例

转载自 http://www.cnblogs.com/wendingding/p/3869804.html html


1、使用代码的方式批量添加(导入)数据到数据库中ios

1.执行SQL语句在数据库中添加一条信息sql

插入一条数据的sql语句:数据库

  

点击run执行语句以后,刷新数据app

2.在ios项目中使用代码批量添加多行数据示例dom

  代码示例:编辑器

//
//  main.m
//  01-为数据库添加多行数据
//
//  Created by apple on 14-7-26.
//  Copyright (c) 2014年 wendingding. All rights reserved.
//
#import <Foundation/Foundation.h>
int main(int argc, const char * argv[])
{
    @autoreleasepool {
        NSArray *names=@[@"张一",@"张二",@"张三",@"张四"];
        NSMutableString *sql=[NSMutableString string];
        
        for (int i=0; i<200; i++) {
            int ID=i+1;
            //这里的警告为无符号类型转换
            NSString *name=names[arc4random_uniform(names.count)];
            name=[name stringByAppendingFormat:@"-%d",arc4random_uniform(200)];
            //生成随机数,范围以20为中心上下波动10
            int age=arc4random_uniform(20)+10;
            [sql appendFormat:@"INSERT INTO t_student (id,name,age) VALUES (%d,'%@',%d);\n",ID,name,age];
        }
        //把sql写入到文件中
        [sql writeToFile:@"/Users/apple/Desk/students.sql" atomically:YES encoding:NSUTF8StringEncoding error:nil];
        NSLog(@"\n%@",sql);
        }
    return 0;
}

做用:生成200条相应的sql插入语句ide

打印结果为:atom

使用文本编辑器,打开生成的sql文件。spa

能够把这些SQL语句拷贝到Navicat中进行执行,也能够直接执行整个文件。

在数据库中建立一张表:

选择执行SQL文件:

    

执行完毕后,点击cancel。

刷新数据库,查看插入的200条数据

 

2、分页简单演示

说明:

使用limit能够精确地控制查询结果的数量,好比每次只查询10条数据

格式 select * from 表名 limit 数值1, 数值2 ;

示例

select * from t_student limit 4, 8 ;

能够理解为:跳过最前面4条语句,而后取8条记录

limit经常使用来作分页查询,好比每页固定显示5条数据,那么应该这样取数据

第1页:limit 0, 5

第2页:limit 5, 5

第3页:limit 10, 5

第n页:limit 5*(n-1), 5

 

下面语句的做用

select * from t_student limit 7 ;

至关于select * from t_student limit 0, 7 ;表示取最前面的7条记录

 

3、补充

1.关于外键约束(创建起两张表之间的联系)

第一种作法:能够新建一张关系表,让以前两张表(班级表和学生表创建起对应的联系),可是这种作法很冗余,没有必要

第二种作法:使用外键约束

一对一,一对多,多对多关系。当两张表有联系时,如何设置外键(在哪张表中设置?)

 

2.关于表链接

子查询:要求查询全部类型为粤菜的菜名。

查询结果为:

链接查询:

查询结果为:

相关文章
相关标签/搜索