Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 276|回复: 0

[默认分类] sqlite3 数据库操作

[复制链接]
  • TA的每日心情
    开心
    2021-12-13 21:45
  • 签到天数: 15 天

    [LV.4]偶尔看看III

    发表于 2018-7-10 13:23:08 | 显示全部楼层 |阅读模式

    1. #import "IWViewController.h"
    2. #import <sqlite3.h>
    3. @interface IWViewController ()
    4. {
    5.     sqlite3 *_db; // db代表着整个数据库,db是数据库实例
    6. }
    7. - (IBAction)insert;
    8. - (IBAction)update;
    9. - (IBAction)delete;
    10. - (IBAction)query;
    11. @end
    12. @implementation IWViewController
    13. - (void)viewDidLoad
    14. {
    15.     [super viewDidLoad];
    16.    
    17.     // 0.获得沙盒中的数据库文件名
    18.     NSString *filename = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"student.sqlite"];
    19.    
    20.     // 1.创建(打开)数据库(如果数据库文件不存在,会自动创建)
    21.     int result = sqlite3_open(filename.UTF8String, &_db);
    22.     if (result == SQLITE_OK) {
    23.         NSLog(@"成功打开数据库");
    24.         
    25.         // 2.创表
    26.         const char *sql = "create table if not exists t_student (id integer primary key autoincrement, name text, age integer);";
    27.         char *errorMesg = NULL;
    28.         int result = sqlite3_exec(_db, sql, NULL, NULL, &errorMesg);
    29.         if (result == SQLITE_OK) {
    30.             NSLog(@"成功创建t_student表");
    31.         } else {
    32.             NSLog(@"创建t_student表失败:%s", errorMesg);
    33.         }
    34.     } else {
    35.         NSLog(@"打开数据库失败");
    36.     }
    37. }
    38. - (IBAction)insert
    39. {
    40.     for (int i = 0; i<30; i++) {
    41.         NSString *name = [NSString stringWithFormat:@"Jack-%d", arc4random()%100];
    42.         int age = arc4random()%100;
    43.         NSString *sql = [NSString stringWithFormat:@"insert into t_student (name, age) values("%@", %d);", name, age];
    44.         
    45.         char *errorMesg = NULL;
    46.         int result = sqlite3_exec(_db, sql.UTF8String, NULL, NULL, &errorMesg);
    47.         if (result == SQLITE_OK) {
    48.             NSLog(@"成功添加数据");
    49.         } else {
    50.             NSLog(@"添加数据失败:%s", errorMesg);
    51.         }
    52.     }
    53. }
    54. - (IBAction)update
    55. {
    56. }
    57. - (IBAction)delete
    58. {
    59.    
    60. }
    61. - (IBAction)query
    62. {
    63.     // SQL注入漏洞
    64.    
    65.     /**
    66.      登录功能
    67.      
    68.      1.用户输入账号和密码
    69.      * 账号:123" or 1 = 1 or "" = "
    70.      * 密码:456654679
    71.      
    72.      2.拿到用户输入的账号和密码去数据库查询(查询有没有这个用户名和密码)
    73.      select * from t_user where username = "123" and password = "456";
    74.      
    75.      
    76.      select * from t_user where username = "123" and password = "456";
    77.      */
    78.    
    79.     // 1.定义sql语句
    80.     const char *sql = "select id, name, age from t_student where name = ?;";
    81.    
    82.     // 2.定义一个stmt存放结果集
    83.     sqlite3_stmt *stmt = NULL;
    84.    
    85.     // 3.检测SQL语句的合法性
    86.     int result = sqlite3_prepare_v2(_db, sql, -1, &stmt, NULL);
    87.     if (result == SQLITE_OK) {
    88.         NSLog(@"查询语句是合法的");
    89.         
    90.         // 设置占位符的内容
    91.         sqlite3_bind_text(stmt, 1, "jack", -1, NULL);
    92.         
    93.         // 4.执行SQL语句,从结果集中取出数据
    94. //        int stepResult = sqlite3_step(stmt);
    95.         while (sqlite3_step(stmt) == SQLITE_ROW) { // 真的查询到一行数据
    96.             // 获得这行对应的数据
    97.             
    98.             // 获得第0列的id
    99.             int sid = sqlite3_column_int(stmt, 0);
    100.             
    101.             // 获得第1列的name
    102.             const unsigned char *sname = sqlite3_column_text(stmt, 1);
    103.             
    104.             // 获得第2列的age
    105.             int sage = sqlite3_column_int(stmt, 2);
    106.             
    107.             NSLog(@"%d %s %d", sid, sname, sage);
    108.         }
    109.     } else {
    110.         NSLog(@"查询语句非合法");
    111.     }
    112. }
    113. @end
    复制代码


    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-4-23 15:17 , Processed in 0.378833 second(s), 37 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表