• 05 数据操纵之插入数据 | OushuDB 数据库使用入门


    大家好,这一节课我们来学习数据操纵,在完成数据库的创建后,我们需要对数据库进行读写操作。

    最常见的数据操纵方式包括插入数据、更新数据和删除数据。

    目前OushuDB兼容的表格式中,目前只有ORC和MAGMA格式的表支持更新和删除操作,AO格式的表不支持。

     

    插入数据

    我们可以通过使用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 表名,来查询一下数据。

    通过这样的插入方式,你需要提前知道表中列的顺序。 

    你也可以通过列出列名,并提供对应的数值来插入。

    比如,这条带列名但打乱顺序的命令和上面的那条命令效果相同:

    insert into department (d_id, d_nation,d_city,d_name) values(100,'中国','北京', 'CEO办公室');

     

    同时,这样做的好处是,如果你不知道其中一些列的值,你可以省掉它。比如这条语句,省去了d_city,d_nation和字段,依旧可以正常插入数据。

    insert into department (d_id, d_name) values(111, '其他');

     

    当我们需要插入多行数据时,可以通过多个insert语句来完成,也可以通过带多个数据行的insert语句来完成,我们只需要将这些数据行通过逗号来连接。

    例如,

    insert into department values (101, '开发一部', '中国', '北京'), (102, '开发二部', '美国', '旧金山'), (103, '测试一部', '中国', '香港'), (104, '销售部', '中国', '上海'), (105, '市场部', '中国', '上海'), (106, '财务部', '中国', '广州');

    便可以插入多行数据。

     

    另外,我们也可以插入从其他表单查询的结果。例如我们创建一个新表department_China,用于存储所有在中国的部门。

    那么我们可以根据需求,将department的数据导入过来。例如,我们需要导入所有地理位置在中国的部门数据。

    create table department_China( d_id int, d_name varchar(32), d_city varchar(32) );

    1. INSERT INTO department_China (d_id, d_name, d_city)
    2. SELECT d_id, d_name, d_city FROM department
    3. WHERE d_nation = '中国';

     

    这里使用了一个查询语句,在后面的课程中,我们会具体讲解。

  • 相关阅读:
    带权并查集
    C++QT实现压缩文件、文件夹和解压缩操作
    使用相同版本的vncviewer登录到opensuse15.4的远程桌面tigervnc-1.10.1
    Azure DevOps (六) 通过FTP上传流水线制品到Linux服务器
    Vue3 项目中使用 jsx 详细教程
    22.10.31补卡 22CCPC桂林C题
    php7 改为从栈上分配内在的思路
    Vue3.0 项目启动(打造企业级音乐App)
    java Spring Boot RequestHeader设置请求头,当请求头中没有Authorization 直接400问题解决
    Vue:object变化侦测
  • 原文地址:https://blog.csdn.net/oushukeji/article/details/126020159