• 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 = '中国';

     

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

  • 相关阅读:
    Linux桌面溯源
    银行 IT 服务连续性体系规划思想与灾备自动化切换建设经验
    基于Apache Hudi构建分析型数据湖
    Patroni for opengauss 10:rewind
    06贪心:跳跃游戏
    Repetition Improves Language Model Embeddings
    算法刷题打卡第17天:全局倒置与局部倒置
    1.32 Cubemx_STM32F429串口中断+空闲中断
    Makefile--自动识别编译环境(x86还是arm)进行编译
    【11-导入人人generator项目并自动生成相关的文件&商品子模块的调试&公共模块common子模块的抽离与实现&Lombok插件的安装】
  • 原文地址:https://blog.csdn.net/oushukeji/article/details/126020159