2016 - 3 - 12 SQLite的学习之SQL语言入门
1.SQL语句的特点:
1.1 不区分大小写
1.2 每条语句以;结尾
2.SQL语句中常用关键字:
select,insert,update,from,create,where,desc,order,by,group,table,alter,view,index等。
数据库中不能出现与上述关键字重名的表名和字段。
3.SQL语言种类:
3.1
数据定义语句: Data Defination Language; (DDL)
包括create和drop等操作
包括创建表或者删除表(create table 和 drop table)
3.2
数据操作语言: Data Manipulation Language (DML)
包括insert,update,delete等操作
上述三种操作分别作用于添加,修改,删除表中数据
3.3
数据查询语言:Data Query Language (DQL)
关键字select是DQL中用的最多的操作
其他常用的DQL中的关键字如 where,order by, group by 和 having.
4.SQL语句使用举例
4.1 DDL (数据定义语言)
4.1.1 创建表格
creat table 表名(字段名1 字段类型1,字段名2 字段类型2)
例如 : CREATE table t_student(id integer PRIMARY key, name text);
实际上SQLite是无类型的,就是是申明为integer类型,一样可以存储字符串数据(主键除外)
4.1.2 删除表格
drop table 表名
例如:DROP TABLE t_student;
4.2DML(数据操作语言)
4.2.1 插入数据
insert to 表名 (字段1,字段2)values(字段1的值,字段2的值)
例如:INSERT into t_student(id,name)VALUES(1,'zhengli');
4.2.2 修改数据
update 表名 set 字段1 = 字段1 新值
例如: update t_student set name = 'zhengli';(注意这样写会将表中的所有name的值更改)
4.2.3 删除数据
delete from 表名
例如: delete from t_student ; (与上面的语句一样,会删除表中所有数据!但不会删除表);
在上面的所有语句中,都可以加上条件语句,例如: update t_student set name = 'tangyi'where id = 1;
这样就只会修改 id =1 的数据。同时可以用and表示C语言中的&& or表示||。
4.3 DQL语句 (数据查询语句)
4.3.1 按照条件查询
select 字段1,字段2,... from 表名
select *from 表名 (查询表中所有字段)
4.3.2 排序查询
select * from 表名 oder by 字段名(默认升序)
select * from 表名 order by 字段名 desc (降序)
4.3.3 limit
select *from 表名 order by 字段名 (升序) limit 数值1,数值2
表示从表中取数据并按升序排列,跳过前数值1个数据,取数值2个数据
如: select * from t_student order by id limit 0,5;
升序排序取出前五条数据。
select *from t_student order by age desc limit 2,3;
降序排序 跳过前2条数据 取之后的3条数据
4.3.4 约束
内键约束
建表时可以给特定的字段设置一些约束条件,常见的约束有
1.not null 该字段不能为空
2.unique 该字段的值唯一,不能重复
3. default 制定该字段的默认值
例如: create table t_student (id integer primary key , name text not null unique,age integer not null default 1)
表名该表中的 name字段不能为空且不能重复,age不能为空且默认为1;
外键约束
利用外键约束,可以建立表与表之间的联系
外键约束的一般情况是,一张表的某个字段,引用着另一张表的主键字段
例如:
create table t_student(id integer primary key ,name text,class_id integer constraint fk_t_student_class_id_t_class_id foreign key (class_id) references t_class(id));
2016 - 3 - 12 SQLite的学习之SQL语言入门的更多相关文章
- Oracle学习笔记之四,SQL语言入门
1. SQL语言概述 1.1 SQL语言特点 集合性,SQL可以的高层的数据结构上进行工作,工作时不是单条地处理记录,而对数据进行成组的处理. 统一性,操作任务主要包括:查询数据:插入.修改和删除数据 ...
- (一)Sql学习之sql语言的组成
SQL语言是具有强大查询功能的数据库结构化语言.由以下几部分组成: 1.数据定义类SQL(DDL--DATE DEFINITION LANGUAGE) CREATE-创建数据库及其对象(表,索引,视图 ...
- SQL学习笔记——SQL初入门,Ubuntu下MySQL的安装
刚开始接触sql,于是准备在Ubuntu下学习sql,就跟着itercast的sql教程开始入门了. 下面只是我个人的记录,高手请绕道: 一. 在安装之前,我们可以用下面这个命令通过开放端 ...
- SQL语言入门
内容来源:唐成. PostgreSQL修炼之道[M]. 机械工业出版社, 2015. 此书购买链接:京东 亚马逊 SQL(Structured Query Language) 结构化查询语言 1. 语 ...
- Android中的SQLite使用学习
Android中的SQLite使用学习 SQLite是非常流行的嵌入式关系型数据库,轻载, 速度快,而且是开源.在Android中,runtime提供SQLite,所以我们可以使用SQLite,而且是 ...
- 学习《SQL必知必会(第4版)》中文PDF+英文PDF+代码++福达BenForta(作者)
不管是数据分析还是Web程序开发,都会接触到数据库,SQL语法简洁,使用方式灵活,功能强大,已经成为当今程序员不可或缺的技能. 推荐学习<SQL必知必会(第4版)>,内容丰富,文字简洁明快 ...
- Web安全学习笔记 SQL注入上
Web安全学习笔记 SQL注入上 繁枝插云欣 --ICML8 SQL注入分类 SQL注入检测 一.注入分类 1.简介 SQL注入是一种代码注入技术用于攻击数据驱动的应用程序在应用程序中,如果没有做恰当 ...
- 2016年12月31日 星期六 --出埃及记 Exodus 21:26
2016年12月31日 星期六 --出埃及记 Exodus 21:26 "If a man hits a manservant or maidservant in the eye and d ...
- 2016年12月30日 星期五 --出埃及记 Exodus 21:25
2016年12月30日 星期五 --出埃及记 Exodus 21:25 burn for burn, wound for wound, bruise for bruise.以烙还烙,以伤还伤,以打还打 ...
随机推荐
- log4j输出日志到文件
输出端Appender Appender用来指定日志信息输出到哪个地方,可以同时指定多个输出目的地.Log4j允许将信息输出到许多不同的输出设备中,一个log信息输出目的地就叫做一个Appender. ...
- 简单的验证码识别(opecv)
opencv版本: 3.0.0 处理验证码: 纯数字验证码 (颜色不同,有噪音,和带有较多的划痕) 测试时间 : 一天+一晚 效果: 比较挫,可能是由于测试的图片是在太小了的缘故. 原理: 验证码 ...
- 第一种SUSE Linux IP设置方法
第一种SUSE Linux IP设置方法ifconfig eth0 192.168.1.22 netmask 255.255.255.0 uproute add default gw 192.168. ...
- 使用Axis2建立WebService
Axis是apache重量级的WebService框架,虽然相比Xfire和CXF而言相对比较臃肿,但是企业中最常用的就是Axis,Axis2是Axis的升级版: 建立一个最简单的Axis2 W ...
- 非常有趣的Console
原文地址: http://www.helloweba.com/view-blog-383.html 批量去掉或替换文本中的换行符(notepad++.sublime text2) 原文地址:http: ...
- BZOJ AC800纪念
貌似没什么好纪念的...QAQQQ 好不容易水到了800还是记录一下好了....不过感觉水这么多题没有意义啊[思考熊] 然后就没有然后了恩 不过我到底是为什么才努力的呢...前途一阵迷茫,根本没有什么 ...
- ADO.NET学习
ADO.NET重要的类 在.NET访问MySql数据库时的几点经验! string connstr=Setting.Instance().GetConnectionString("MySql ...
- AseBulkCopy 若干问题的解决方法
场景:数据库 Ase 15.0, Ado.net客户端15.7 Sybase.AdoNet4.AseClient 错误1:使用Transaction报错 错误2: 存储过程"sp_drv_ ...
- sql 生成指定相同数量数据
select *from 表名 ,(SELECT NUMBER FROM master..spt_values WHERE number BETWEEN 1 AND 2 AND TYPE='P' ...
- Windows中一个22年的漏洞
X Windows系统,今天作为世界各地的Linux桌面,已经存在超过20年了,仍然存在Bug.几天前Sysadmins为libXfont库提供了补丁,来对应新发现的已经在代码中存在了22年的特权升 ...