Sqlite常用表查询语句

1、查找一个表返回其中几条记录

select * from table where name = 'XXX'  limit 0,10; 

其中limit 0,10中,0表示从第0条记录开始,10表示向下10条记录。

2、根据条件查找一个表,按某字段进行排序

select * from table where name='XXX' order by id  desc或者 asc 或者不填 ;

desc降序排列,asc升序排列

其中id是表中的字段。

3、查询一个表中,某字段名为X或者Y的所有数据

select * from LocalModelTable where prodCategory = ? or prodCategory = ?;

其中prodCategory为字段,名为X或者Y,返回的是名字为X、Y下的所有数据。

4、更新一条数据到表中

update LocalSchemeTable set  Area = ?,BudgetList = ?,TimeStamp = ?where SchemeID = ?;

5、插入一条记录到表中

insert into LocalSchemeTable (Area, BudgetList,Budget) VALUES (?,?,?);

6、查找出某个字段的所有不同值

select distinct prodCategory from LocalModelTable;

如上,返回的结果集为prodCategory的所有不同值。取值就用prodCategory

7、查询某字段下的所有记录条数(只返回计数)

select count (*) from LocalModelTable where prodCategory = ?;

8、给表添加、删除、修改一列(字段)

1 . alter table table_name add column column_name datatype default 0

举例: alter table student add column age interger default 0

给student表增加一个字段age ,设置默认值为0

  1. alter table table_name drop column column_name

  2. alter table table_name alter column column_name datatype

9、手动添加一个表

create table if not exists LocalProductInfoTable (Num integer primary key autoincrement,marque text);

其中Num为自增长的编号。text为文本类型。

10、查看数据库中是否有某个表

select count(*) as 'count' from sqlite_master where type ='table' and name = ?;

?为表名。

11、给表起别名

select name myname, age myage from student ;

给表中name起个别名叫myname,给age起个别名叫myage。

select s.name , s.age from student s;

给表student一个别名叫s,然后取出s的name和age字段信息。

12、约束

比如有的值不能为空,有的必须给默认值,有的字段的值必须唯一

建表时可以给特定的字段设置一些约束条件,常见的约束有

not null :规定字段的值不能为null

unique :规定字段的值必须唯一

default :指定字段的默认值

(建议:尽量给字段设定严格的约束,以保证数据的规范性)

举例

create table student (id integer, name text not null unique, age integer not null default 1) ;

name字段不能为null,并且唯一

age字段不能为null,并且默认为1

13、添加主键 自增长

主键(Primary Key,简称PK)用来唯一地标识某一条记录,一个表可以有多个主键。只要声明为primary key,就说明是一个主键字段,主键字段默认就包含了not null 和 unique 两个约束。

create table student (id integer primary key, name text, age integer) ;

创建一个student表,设置id为主键。

create table student (id integer primary key autoincrement, name text, age integer) ;

创建一个student表,设置id为主键,并且是自增长类型,需要注意的是,自增长类型主键必须!!!是interger类型的。

14、外键

外键是指本表的某个字段是另外一张表的主键。

15、查询A表中是否有B字段

select count(*) from sqlite_master where type='table' and name='MD5Table' and sql like '%%IfModifiedSince%%';

其中sqlite_master并不是手动创建的,相当于根表,所有手动创建的表都是基于根表, type为查询的类型,name为查询的表名,sql like 。。。是你执行过的语句,这里的IfModifiedSince就相当于字段。

16、给A表中的B字段重命名成C字段

你可能感兴趣的:(Sqlite常用表查询语句)