SQLite3系统学习【3】SQL代码应用
2015-02-09 21:46
411 查看
转载自:http://www.cnblogs.com/wendingding/p/3869804.html
一、使用代码的方式批量添加(导入)数据到数据库中
1.执行SQL语句在数据库中添加一条信息
插入一条数据的sql语句:
点击run执行语句之后,刷新数据
2.在ios项目中使用代码批量添加多行数据示例
代码示例:
作用:生成200条相应的sql插入语句
打印结果为:
使用文本编辑器,打开生成的sql文件。
可以把这些SQL语句拷贝到Navicat中进行执行,也可以直接执行整个文件。
在数据库中创建一张表:
选择执行SQL文件:
执行完毕后,点击cancel。
刷新数据库,查看插入的200条数据
二、分页简单演示
说明:
使用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条记录
三、补充
1.关于外键约束(建立起两张表之间的联系)
第一种做法:可以新建一张关系表,让之前两张表(班级表和学生表建立起对应的联系),但是这种做法很冗余,没有必要
第二种做法:使用外键约束
一对一,一对多,多对多关系。当两张表有联系时,如何设置外键(在哪张表中设置?)
2.关于表连接
子查询:要求查询所有类型为粤菜的菜名。
查询结果为:
连接查询:
查询结果为:
一、使用代码的方式批量添加(导入)数据到数据库中
1.执行SQL语句在数据库中添加一条信息
插入一条数据的sql语句:
点击run执行语句之后,刷新数据
2.在ios项目中使用代码批量添加多行数据示例
代码示例:
1 // 2 // main.m 3 // 01-为数据库添加多行数据 4 // 5 // Created by apple on 14-7-26. 6 // Copyright (c) 2014年 wendingding. All rights reserved. 7 // 8 9 #import <Foundation/Foundation.h> 10 11 int main(int argc, const char * argv[]) 12 { 13 14 @autoreleasepool { 15 NSArray *names=@[@"张一",@"张二",@"张三",@"张四"]; 16 NSMutableString *sql=[NSMutableString string]; 17 18 for (int i=0; i<200; i++) { 19 int ID=i+1; 20 //这里的警告为无符号类型转换 21 NSString *name=names[arc4random_uniform(names.count)]; 22 name=[name stringByAppendingFormat:@"-%d",arc4random_uniform(200)]; 23 //生成随机数,范围以20为中心上下波动10 24 int age=arc4random_uniform(20)+10; 25 [sql appendFormat:@"INSERT INTO t_student (id,name,age) VALUES (%d,'%@',%d);\n",ID,name,age]; 26 } 27 //把sql写入到文件中 28 [sql writeToFile:@"/Users/apple/Desk/students.sql" atomically:YES encoding:NSUTF8StringEncoding error:nil]; 29 NSLog(@"\n%@",sql); 30 } 31 return 0; 32 }
作用:生成200条相应的sql插入语句
打印结果为:
使用文本编辑器,打开生成的sql文件。
可以把这些SQL语句拷贝到Navicat中进行执行,也可以直接执行整个文件。
在数据库中创建一张表:
选择执行SQL文件:
执行完毕后,点击cancel。
刷新数据库,查看插入的200条数据
二、分页简单演示
说明:
使用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条记录
三、补充
1.关于外键约束(建立起两张表之间的联系)
第一种做法:可以新建一张关系表,让之前两张表(班级表和学生表建立起对应的联系),但是这种做法很冗余,没有必要
第二种做法:使用外键约束
一对一,一对多,多对多关系。当两张表有联系时,如何设置外键(在哪张表中设置?)
2.关于表连接
子查询:要求查询所有类型为粤菜的菜名。
查询结果为:
连接查询:
查询结果为:
相关文章推荐
- SQLite3系统学习【2】SQL语句
- SQLServerToSQLite 程序代码的分析翻译及学习(一、SQLServer数据库对象化提取)
- linux下sqlite3的安装、sql语句学习、c代码编程
- SQLite3系统学习【4】SQLite的应用
- IOS学习之数据库(3)--SQL代码应用示例
- SQLServerToSQLite 程序代码的分析翻译及学习(二、根据数据库描述对象创建SQLite数据库)
- SQL综合应用学习(二)
- SQL综合应用学习
- 投票系统[单/复选,投票数量/项随意][C#/SQL/文件包括数据库代码全部在]
- 一步一步学习OC2007(五)--OC与 Web 应用系统的集成
- 我们一起学习 sqlite 的应用
- SQL 全文检索应用 [转载](学习)
- 某排课(调课)系统课时表数据自动形成T-SQL代码
- MS SQL Server 2000 中系统表应用技巧
- 奉献给搞.NET和学习.NET的学习资料和自己收集的代码,个人的知识库系统
- 网络应用系统---系统设计架构个人项目实战示例(各种页面代码A)
- 我们一起学习 sqlite 的应用
- 关于pl/sql调用java的学习总结(附代码)
- 学习_孙亚民的"构建面向对象的应用软件系统框架"