iOS Sqlite3 SQL 语句

sqlite3SQL语句的特点


  • 不区分大小写(比如数据库认为user和UsEr是一样的)
    每条语句都必须以分号 “ ; ” 就是分号结尾。

SQL中的常用关键字有


  • select、insert、update、delete、from、create、where、desc、order、by、group、table、alter、view、index等等
  • 数据库中不可以使用关键字来命名表、字段

数据定义语句 DDL、DML、DQL


  • DDL:(Data Definition Language)包括create和drop等操作
    在数据库中创建新表或删除表(create table或 drop table)
  • DQL: ( Data Query Language)可以用于查询获得表中的数据
    关键字select是DQL(也是所有SQL)用得最多的操作, 其他DQL常用的关键字有where,order by,group by和having
  • DML: ( Data Manipulation Language)包括insert、update、delete等操作
    上面的3种操作分别用于添加、修改、删除表中的数据

创表---格式


  • create table 表名 (字段名1 字段类型1, 字段名2 字段类型2, …) ;
    create table if not exists 表名 (字段名1 字段类型1, 字段名2 字段类型2, …) ;
示例:
create table t_student (id integer, name text, age inetger, score real) 

字段类型


  • SQLite将数据划分为以下几种存储类型:
    integer : 整型值
    real : 浮点值
    text : 文本字符串
    blob : 二进制数据(比如文件)

实际上SQLite是无类型的
就算声明为integer类型,还是能存储字符串文本(主键除外)
建表时声明啥类型或者不声明类型都可以,也就意味着创表语句可以这么写:
create table t_student(name, age);

为了保持良好的编程规范、方便程序员之间的交流,编写建表语句的时候最好加上每个字段的具体类型

删表---格式


  • drop table 表名 ;
    drop table if exists 表名 ;
// 示例
drop table t_student ;

插入数据(insert)---格式


  • 格式: insert into 表名 (字段1, 字段2, …) values (字段1的值, 字段2的值, …) ;
// 示例
insert into t_student (name, age) values (‘mj’, 10) ;
  • 注意
    数据库中的字符串内容应该用单引号 ’ 括住

更新数据(update)---格式


  • update 表名 set 字段1 = 字段1的值, 字段2 = 字段2的值, … ;
// 示例
update t_student set name = ‘jack’, age = 20 ; 
  • 注意
    上面的示例会将t_student表中所有记录的name都改为jack,age都改为20

删除数据(delete)---格式


  • delete from 表名 ;
// 示例
delete from t_student ;
  • 注意
    上面的示例会将t_student表中所有记录都删掉

数据库相对 plist的好处


  • 分页查询指令

limit 指令用于限制查询出来的结果数量

  • 第一个数值表示从哪条记录开始(起始是0)
  • 第二个数值表示一次取多少条记录,如果要分页显示,通常第二个数值固定不变,表示每页需要显示的记录条数
  • 第一页
    select * from t_person limit 0, 3;
  • 第二页
    select * from t_person limit 3, 3;
  • 第三页
    select * from t_person limit 6, 3;

查询排序


  • ASC 升序(默认的排序方法)
  • DESC 降序
  • 由左至右排序的优先级依次降低,也就是第一个排序列的优先级是最高的
    SELECT * FROM t_person ORDER BY age ASC, id DESC;

能够定向地查到具体需要的内容


  • 从数据库查出名字叫做wangwu的记录
    select * from t_person where name = 'wangwu';
  • 从数据库查出名字以wang开头的记录
    select * from t_person where name like 'wangwu%';
  • 从数据库查出名字中包含a的记录,通常用于模糊查询,建议不要搞太多字段组合模糊查询,那样性能会非常差!
    select * from t_person where name like '%a%';

可以对数据进行统计


  • 取出所有数据的总数目
    select count(*) from t_person;
  • 统计符合条件的记录条数
    select count(*) from t_person where name like 'wang%';
  • 选择指定列的最大值
    select max(age) from t_person;
  • 选择指定列的最小值
    select min(age) from t_person;
  • 计算指定列的平均值
    select avg(age) from t_person;
  • 计算指定列数值的总数
    select sum(age) from t_person;

更新指令


  • 更新一个字段
    update t_person set name = 'xiaofang' where name = 'wangwu';
  • 更新多个字段,每个字段之间使用,分隔
    update t_person set age = 20, height = 2.0 where name = 'xiaofang';

1、需要注意的是:使用更新指令时,最好能够准确地知道唯一的一条要更新的记录,否则其他所有满足条件的记录都会被修改。

2、自动增长是由服务器来控制的。


关系

为什么要有关系
  1. 数据“冗余”,所谓数据冗余,就是存储了多余的数据
  2. 在数据库中的关系有:
  • 一对一
  • 一对多
  • 多对一

通常,一对多和多对一关系存储在时,就需要使用多个表表示。

关于left jion和jion的选择

left join


1)如果要查询左边表中的所有符合条件的数据,使用left jion

  1. 通常查询出来的结果会多,因为右边表不存在的记录,同样可能会被查询出来,查询出来之后,右边表不存在的记录,全部为NULL

join


1)如果要两个表中同时存在的符合条件的数据,使用jion

  1. 通常查询出来的结果会比左连接少,因为右边表不存在的记录,不会显示出来
通常在使用时,左边的表是主要信息表,右边的表是辅助修饰的信息表,其内容可有可无,因此,在实际应用中,left jion使用的比较频繁!如果用join的话,有可能会“丢(有些存在的数据不显示)”数据

在使用连接查询多个表时,如果有重名的字段,可以使用 as 的方法,给字段起一个别名,示例代码如下:

select s.name, s.age, s.phone, b.name as bookname, b.price from t_student s
join t_book b on b.id = s.book_id
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,560评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,104评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,297评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,869评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,275评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,563评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,833评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,543评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,245评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,512评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,011评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,359评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,006评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,062评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,825评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,590评论 2 273
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,501评论 2 268

推荐阅读更多精彩内容