SQLite Insert 语句
在上面章节中我们已经创建了表 company 和 department 两张表 现在我们要把公司的信息录入到这两张表里,要怎么做呢?
SQLite 提供了 INSERT INTO 语句用于向表中添加新的数据行
语法
INSERT INTO 语句有两种基本语法
INSERT INTO table_name [(column1, column2, column3,...columnN)] VALUES (value1, value2, value3,...valueN);
在这里,column1, column2,...columnN 是要插入数据的表中的列的名称
如果要为表中的所有列添加值,可以不用在指定列名称, 但要确保值的顺序与列在表中的顺序一致。
SQLite 的 INSERT INTO 语法如下:
INSERT INTO table_name VALUES (value1,value2,value3,...valueN);
范例
我们使用前一章节中创建的 company 表,结构如下
sqlite> .schema company CREATE TABLE company ( id INT PRIMARY KEY NOT NULL, name TEXT NOT NULL, age INT NOT NULL, address CHAR(50), salary REAL );
如果没创建,可以拷贝上面的 CRATE TABLE 开始的语句创建 company 表
现在,我们要用下面的语句把我们的员工信息添加到表中
一条一条执行
sqlite> INSERT INTO COMPANY (id,name,age,address,salary) VALUES (1, 'Paul', 32, 'California', 20000.00 ); sqlite> INSERT INTO COMPANY (id,name,age,address,salary) VALUES (2, 'Allen', 25, 'Texas', 15000.00 ); sqlite> INSERT INTO COMPANY (id,name,age,address,salary) VALUES (3, 'Teddy', 23, 'Norway', 20000.00 );
3条一起执行
sqlite> INSERT INTO COMPANY (id,name,age,address,salary) VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 ); INSERT INTO COMPANY (id,name,age,address,salary) VALUES (5, 'David', 27, 'Texas', 85000.00 ); INSERT INTO COMPANY (id,name,age,address,salary) VALUES (6, 'Kim', 22, 'South-Hall', 45000.00 ); sqlite>
上面的语句 6 条 INSERT INTO 语句可以一条一条拷贝到交互命令行里执行,也可以一起拷贝过去执行
我们再用第二种 INSERT INTO 语法向表中创建一个记录
sqlite> INSERT INTO COMPANY VALUES (7, 'James', 24, 'Houston', 10000.00 ); sqlite>
上面的所有语句将在 company 表中创建下列记录
我们会在下一章 SELECT 中告诉大家怎么查看我们插入的数据
id name age address salary ---------- ---------- ---------- ---------- ---------- 1 Paul 32 California 20000.0 2 Allen 25 Texas 15000.0 3 Teddy 23 Norway 20000.0 4 Mark 25 Rich-Mond 65000.0 5 David 27 Texas 85000.0 6 Kim 22 South-Hall 45000.0 7 James 24 Houston 10000.0
我们也可以使用一个表来填充另一个表
可以通过在一个有一组字段的表上使用 select 语句,填充数据到另一个表中
INSERT INTO first_table_name [(column1, column2, ... columnN)] SELECT column1, column2, ...columnN FROM second_table_name [WHERE condition];
我们暂时先跳过上面的语句,等以后学习到了 SELECT 和 WHERE 子句再回来看这个