大家好,这一节课我们来学习数据操纵,在完成数据库的创建后,我们需要对数据库进行读写操作。
最常见的数据操纵方式包括插入数据、更新数据和删除数据。
目前OushuDB兼容的表格式中,目前只有ORC和MAGMA格式的表支持更新和删除操作,AO格式的表不支持。
https://img-blog.csdnimg.cn/010cf8d530ed4471ac28839dce6172d1.png
插入数据
我们可以通过使用INSERT命令来创建一个新行,命令中要求提供表名字以及列值。
例如,我们在上节中创建了部门信息表:
create table department( d_id int, d_name varchar(32), d_nation varchar(32), d_city varchar(32) );
我们可以通过
insert into department values(100, 'CEO办公室','中国','北京');
来插入一行数值,数据值用逗号进行分隔,顺序与这些列在表中出现的顺序一致。
然后我们用select * from 表名,来查询一下数据。
https://img-blog.csdnimg.cn/img_convert/061b39f7613ac352b60507cd55509eae.jpeg
通过这样的插入方式,你需要提前知道表中列的顺序。
你也可以通过列出列名,并提供对应的数值来插入。
比如,这条带列名但打乱顺序的命令和上面的那条命令效果相同:
insert into department (d_id, d_nation,d_city,d_name) values(100,'中国','北京', 'CEO办公室');
https://img-blog.csdnimg.cn/85a101ffb07c4243a4caa461ce5d6350.png
同时,这样做的好处是,如果你不知道其中一些列的值,你可以省掉它。比如这条语句,省去了d_city,d_nation和字段,依旧可以正常插入数据。
insert into department (d_id, d_name) values(111, '其他');
https://img-blog.csdnimg.cn/d8b814a2b97f4b369a0b39648af7445d.png
当我们需要插入多行数据时,可以通过多个insert语句来完成,也可以通过带多个数据行的insert语句来完成,我们只需要将这些数据行通过逗号来连接。
例如,
insert into department values (101, '开发一部', '中国', '北京'), (102, '开发二部', '美国', '旧金山'), (103, '测试一部', '中国', '香港'), (104, '销售部', '中国', '上海'), (105, '市场部', '中国', '上海'), (106, '财务部', '中国', '广州');
便可以插入多行数据。
https://img-blog.csdnimg.cn/e75c78c8ab684597afd2de32d32411fe.png
另外,我们也可以插入从其他表单查询的结果。例如我们创建一个新表department_China,用于存储所有在中国的部门。
那么我们可以根据需求,将department的数据导入过来。例如,我们需要导入所有地理位置在中国的部门数据。
create table department_China( d_id int, d_name varchar(32), d_city varchar(32) );
INSERT INTO department_China (d_id, d_name, d_city)
SELECT d_id, d_name, d_city FROM department
WHERE d_nation = '中国';
https://img-blog.csdnimg.cn/d39983445b954aa5b8a40e617821c383.png
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。




