常用命令:
.sqlite3 --从dos命令模式进入sqlite命令行
.quit --退出sqlite命令行,回到dos命令
.databases  --查看有哪些数据库
.tables  --查看有哪些表
.schema 表名 --查看指定的表的DDL(表结构)
 
sqlite数据库中特殊的表    (系统自带表)sqlite_master
select name from sqlite_master where type='table'; 

字符串连接用 ||

--sqlite中查找所有表对应的select count(*) 语句:

select  'select count(*) from '||name||';' from sqlite_master where type='table';

 
创建/打开指定名称的数据库 .sqlite3 test.db (dos命令行输入,有则打开指定名称的数据库,没有则创建指定名称的数据)
 
导入数据: .read 数据文件(如 .read a.sql,数据库脚本文件放到数据库名.db相同路径下)

 
删除数据库表  drop table actor(表名字);
 
 
建表语句:
 
--基本建表1
CREATE TABLE employees (
    emp_no int(11) NOT NULL,
    birth_date date NOT NULL,
    first_name varchar(14) NOT NULL,
    last_name varchar(16) NOT NULL,
    gender char(1) NOT NULL,
    hire_date date NOT NULL,
    PRIMARY  KEY (emp_no)
)
 
--基本建表2
CREATE TABLE actor (
    actor_id smallint(5) NOT NULL,
    first_name  varchar(45) NOT NULL,
    last_name varchar(45) NOT NULL,
    last_update  timestamp NOT NULL DEFAULT (datetime('now','localtime')),
    PRIMARY  KEY (actor_id)
);
 
--建表同时建索引
CREATE TABLE salaries (
    emp_no int(11) NOT NULL,
    salary int(11) NOT NULL,
    from_date date NOT NULL,
    to_date date NOT NULL,
    PRIMARY  KEY (emp_no, from_date)
);
CREATE INDEX idx_emp_no ON salaries (emp_no);
 
--如果表已经存在就不创建
CREATE TABLE IF NOT EXISTS film (film_id smallint(5) NOT NULL);
 
注意,对于已经建好的表,sqlite中不能通过Alter table 来添加外健。

https://www.nowcoder.com/questionTerminal/aeaa116185f24f209ca4fa40e226de48

 
--花式建表
1.快速复制/备份一个表的数据
create table actor_backup20180106 as select * from actor;
注意:这种方式会把默认值、主键约束、NOT NULL等等这些给玩丢了。
2.已知表A,并且已经有数据,创建表B,并且表B的字段都(或部分)来源于表A,并导入表A对应的数据
解法1:
CREATE TABLE actor_name (
    first_name  varchar(45) NOT NULL,
    last_name varchar(45) NOT NULL
);
insert into actor_name  select first_name, last_name from actor;
解法2:
create table actor_name as select first_name,last_name from actor;
解法2更方便,但是会丢失Not Nul 主键等信息。
 
--插入数据
用inset into 表名 select插入子查询的结果集
inset into 表名 values (....),(.....),(......)
inset into 表名(字段1,字段2,字段3....)   values (....),(.....),(......)
 
--插入单条数据
INSERT INTO employees VALUES (1,datetime('1986-01-12 04:00'),'Luoke','Li','M',datetime('2010-01-12 04:00'));
--批量插入数据(多条Insert)
BEGIN TRANSACTION;
INSERT INTO actor  VALUES (1,'PENELOPE','GUINESS',datetime('2006-02-15 12:34:33'));
INSERT INTO actor  VALUES (2,'NICK','WAHLBERG',datetime('2006-02-15 12:34:33'));
COMMIT;
 
--用一条sql语句就批量插入多条数据-方法1
INSERT INTO actor(actor_id,first_name,last_name,last_update)
select 3,'Jones','Jim',datetime('2006-02-15 12:34:33')
UNION ALL
select 4,'DiLun','Bob',datetime('2006-02-15 12:34:33');
--用一条sql语句就批量插入多条数据-方法2
INSERT INTO actor values(5,'Luffy','MonkeyD',datetime('2006-02-15 12:34:33')),(6,'SuoLong','Luoluonua',datetime('2006-02-15 12:34:33'));
 
--用一条sql语句就批量插入多条数据并且不要插入已存在的数据(不能用replace)--方法1
INSERT INTO actor
select 5,'Luffy','MonkeyD',datetime('2006-02-15 12:34:33') where not exists(select * from actor where actor_id=5);
--用一条sql语句就批量插入多条数据并且不要插入已存在的数据(不能用replace)--方法2
在 SQLite 中,用 INSERT OR IGNORE 来插入记录,或忽略插入与表内UNIQUE字段都相同的记录
INSERT OR IGNORE INTO actor VALUES (3, 'ED', 'CHASE', '2006-02-15 12:34:33');
 
用 INSERT OR REPLACE 来插入记录,或更新替代与表内UNIQUE字段都相同的记录
INSERT OR REPLACE INTO actor VALUES (3, 'ED', 'CHASE', '2006-02-15 12:34:33')
 
REPLACE   用法详解
 
 
创建索引:
CREATE UNIQUE INDEX uniq_idx_firstname on actor  (first_name); --创建唯一索引
CREATE INDEX idx_lastname on actor  (last_name); --创建普通索引
 
强制索引查询--SQLite中,使用 INDEXED BY 语句进行强制索引查询
SELECT * FROM salaries INDEXED BY idx_emp_no WHERE emp_no = 10005
 
 
创建视图:
create view actor_name_view as select first_name as fist_name_v, last_name as last_name_v from actor;
等价于
CREATE VIEW actor_name_view (fist_name_v, last_name_v) AS  SELECT first_name, last_name FROM actor
 
--日期时间
select datetime('now','localtime'); --获取系统当前时间

转义字符如:

--' 默认情况下, '是字符串的边界符, 如果在字符串中包含', 则必须使用两个', 第1个'就是转义符

select last_name||''''||first_name from employees;

(或SELECT last_name || "'" || first_name FROM employees;)

常用字符串函数:

length  replace   substr

replace函数的用法:replace('A','b','c') 用c替换字符串A中所有的b

例子:

select (length('10,A,B')-length(replace('10,A,B',",",""))/length(','));

函数:substr(string string,num start,num length)用法:
string为字符串;
start为起始位置;字符串的第一个字符的位置为1,不是从0开始计算
length为长度。

/*例如:获取某个字符串中最后2个字母
select substr('abcdefg',length('abcdefg')-1,2);*/

Sqlite常用命令及基本知识的更多相关文章

  1. linux 常用命令及零散知识

    磁盘管理常用命令 fdisk -l //展示磁盘使用情况 df -h      //展示目录挂载情况 du -sh   //查文件.文件夹的总大小 scp /home/a.txt /home/b.tx ...

  2. SQLite常用命令

    1.点命令 [退出SQLite提示符] .quit .exit [帮助] .help [显示设置] .show 2.语法 [结束符] : --一行语句的结束以分号(:)结尾 [CREATE TABLE ...

  3. sqlite 常用命令

    1)创建数据库文件: >sqlite3 /home/test.db 回车 就生成了一个test.db在/home路径下. 这样同时也SQLite3加载了这个test.db 2)用.help可以看 ...

  4. SQLite常用命令总结

    1) 创建数据库文件: >SQLite3 d:\test.db 回车 就生成了一个test.db在d盘. 这样同时也SQLite3挂上了这个test.db 2) 用.help可以看看有什么命令 ...

  5. Android SQLite3工具常用命令行总结

    Android SDK的tools目录下提供了一个sqlite3.exe工具,这是一个简单的sqlite数据库管理工具.开发者可以方便的使用其对sqlite数据库进行命令行的操作. 程序运行生成的*. ...

  6. 计算机硬件基本知识及Linux的常用命令

    ------------------1. 计算机硬件基本知识------------------ CPU - 寄存器 - L1/L2/L3 - 内存 - 硬盘 - 互联网下载/其他存储介质传输 寄存器 ...

  7. sqlite常用的命令-增删改查

    一.查看版本信息: #sqlite3 -version 二.sqlite3常用命令 1.当前目录下建立或打开test.db数据库文件,并进入sqlite命令终端,以sqlite>前缀标识: 2. ...

  8. Shell编程(二)——shell的基础知识及常用命令

    shell的基础知识 一.bash有以下特点: 1.记录命令历史 2.指令和文件名补全 3.别名 alias rm='rm -i' 4.通配符 * 0个或多个字符 ?​匹配一个字符 5 输入输出重定向 ...

  9. 五个知识体系之-Linux常用命令学习

    1.ls命令 就是list的缩写,通过ls 命令不仅可以查看linux文件夹包含的文件,而且可以查看文件权限(包括目录.文件夹.文件权限)查看目录信息等等 常用参数搭配: ls -a 列出目录所有文 ...

随机推荐

  1. [转]JS - Promise使用详解2(ES6中的Promise)

    原文地址:https://www.hangge.com/blog/cache/detail_1638.html 2015年6月, ES2015(即 ECMAScript 6.ES6) 正式发布.其中  ...

  2. 026_如何在MAC下输入主要国家货币符号?

    由于出国旅游啥的经常会记录一些东西,不避免的会遇到各种货币符号 一. 人民币: ¥(sogo输入法切换到中文模式,然后"shift键 + 4"即可) 美元: $(sogo输入法切换 ...

  3. 【转】HTML meta标签总结与属性使用介绍

    HTML meta标签总结与属性使用介绍 转载处写的已经超级好了,强烈推荐. 转自:https://segmentfault.com/a/1190000004279791 本人就不再赘述.拿来主义!供 ...

  4. WebGL调试工具分享

    学习WebGL,我们需要一些好用的调试工具,下面分享3个常用的调试工具. WebGL Inspector 下载地址:https://github.com/benvanik/WebGL-Inspecto ...

  5. 服务器推送(Server push)技术总结

    1. 短轮询 ajax按一定间隔去请求 2. 长轮询(long Polling) Long Polling的实现很简单,可分为四个过程: 发起Polling发起Polling很简单,只需向服务器发起请 ...

  6. [译]使用BeautifulSoup和Python从网页中提取文本

    如果您要花时间浏览网页,您可能遇到的一项任务就是从HTML中删除可见的文本内容. 如果您使用的是Python,我们可以使用BeautifulSoup来完成此任务. 设置提取 首先,我们需要获取一些HT ...

  7. VisualStudio开发UE4工程设置

    转自:http://wangjie.rocks/2016/06/24/ue4-vs-setup/ 推荐插件 Visual Assist X C++ 代码高亮 UnrealVS Extension UE ...

  8. 在ObjectARX中创建OPM项目的时候出现 MIDL1012: argument illegal for switch / header错误的解决方式

    修改为 这样新建的带有MIDL项目就不会提示错误这个错误了. 如果你已经建立好项目,可以尝试修改MIDL的配置,头文件可能是.h没有文件名,所以出现MIDL1012错误,修改为项目名称的.h即可,保持 ...

  9. example

    import pandas as pd import numpy as np import os,sys df = pd.read_excel("C:\\Users\\ryanzhang\\ ...

  10. CMDB和自动化运维

    CMDB和自动化运维 IT运维的分类 IT运维,指的是对已经搭建好的网络,软件,硬件进行维护.运维领域也是细分的,有硬件运维和软件运维 硬件运维主要包括对基础设施的运维,比如机房的设备,主机的硬盘,内 ...