数据库操作系列-Mysql, Postgres常用sql语句总结

文章目录

    • 1.如果我想要写一句sql语句,实现 如果存在则更新,否则就插入新数据,如何解决?
      • MySQL数据库实现方案: ON DUPLICATE KEY UPDATE
        • 写法
      • Postgres数据库实现方案:
        • 方案1:
        • 方案2:
        • 关于更新:如何实现,当app_name数据存在,就更新details呢??
    • 2.模糊查询+不区分大小写
    • 3. 查询某个字段是否属于多个值中的一个,或者说,等于多个值中的一个就筛选出来
    • 4. 时间范围查询
    • 5. Postgres数据库如何使用dbever批量添加字段,设置类型
      • 1. 新建一张表
      • 2. 打开一个sql编辑器
      • 3. 编写sql语句,下面给大家一些参考句子
      • 4. 执行语句
      • 5. 建表成功
    • 6. 一些常用的Mysql简单指令
      • 丢弃指定的数据库,如果存在的话
      • 创建新的数据库
      • 进入数据库tangdoudou
      • 创建表
      • 向表中插入数据
      • 查询表中所有数据
      • 修改数据
      • 删除数据
      • 一些常用栗子:
        • 丢弃指定的数据库tangdoudou,如果存在
        • 创建一个新的数据库
        • 进入数据库tangdoudou
        • 创建保存学生数据的表(编号、姓名、性别、分数);
        • 往学生表中插入数据
        • 修改编号为2的学员成绩为100,姓名为lucy;
        • 删除编号为3的学员数据
        • 查询学生表内容
    • 待继续补充
      • 欢迎路过的小哥哥小姐姐们提出更好的意见哇~~

1.如果我想要写一句sql语句,实现 如果存在则更新,否则就插入新数据,如何解决?

MySQL数据库实现方案: ON DUPLICATE KEY UPDATE

在MySQL数据库中,如果在insert语句后面带上ON DUPLICATE KEY UPDATE 子句,而要插入的行与
表中现有记录的惟一索引或主键中产生重复值,那么就会发生旧行的更新;如果插入的行数据与现有表
中记录的唯一索引或者主键不重复,则执行新记录插入操作。
简而言之:数据存在则更新,无则创建

写法


INSERT INTO 表名 (字段名1, 字段名2 ) 
VALUES (字段值1, 字段值2) 
ON DUPLICATE KEY UPDATE 字段名1 = VALUES(字段名1), 字段名2 = VALUES(字段名2)

Postgres数据库实现方案:

注意事项:

  • ON CONFLICT 只在 PostgreSQL 9.5 以上可用。
  • 做判断的字段必须有索引约束。例如Unique唯一索引做约束

方案1:

假如我们有这个app表,现在把其中一列name设置为unique

ALTER TABLE public.applications ADD CONSTRAINT applications_un UNIQUE (name);

然后我们去写代码

这个语句: 当数据存在时,什么都不做(DO NOTING)


const insertApp = await client.query(`INSERT INTO applications (app_name, details ) VALUES ('${appName}', '${appDetail}') ON CONFLICT ON CONSTRAINT applications_un  DO NOTHING;`);

方案2:

下面的语句有一样的效果,区别在于使用的是 name 字段,而不是约束的名字


INSERT INTO customers (app_name, details)
VALUES('AAA','BBBBBB') 
ON CONFLICT (name) 
DO NOTHING;

关于更新:如何实现,当app_name数据存在,就更新details呢??


INSERT INTO customers (app_name, details)
VALUES('AAA','BBBBBB') 
ON CONFLICT (name) 
DOUPDATESET email = 'CCCCCCCC';
upsert

使用相同变量,多次执行这段逻辑,我们会发现只创建了一条,所以是成功的~~~

2.模糊查询+不区分大小写

举个栗子:从users表里查询details信息和user_name信息包含字母’xiaojin’

select * from users where lower(details) like '%xiaojin%' or lower(user_name) like '%xiaojin%' 

3. 查询某个字段是否属于多个值中的一个,或者说,等于多个值中的一个就筛选出来

举个栗子: 从users表查询type类型为Admin 或者 Super Admin

select * from users where "type" in ('Admin', 'Super Admin') 

4. 时间范围查询

举个栗子: 我想查询users表created_at字段从2023-08-01 00:00:00.000 到2023-08-10 00:00:00.000范围内的数据

select * from users where created_at between '2023-08-01 00:00:00.000' and '2023-08-10 00:00:00.000'

5. Postgres数据库如何使用dbever批量添加字段,设置类型

1. 新建一张表


2. 打开一个sql编辑器

3. 编写sql语句,下面给大家一些参考句子

ALTER TABLE public.users ADD id serial4 NOT NULL;ALTER TABLE public.users ADD "user_name" varchar(255) NULL;ALTER TABLE public.users ADD description varchar(255) NULL;ALTER TABLE public.users ADD "type" varchar(255) NULL;ALTER TABLE public.users ADD created_at timestamp(6) NULL;ALTER TABLE public.users ADD updated_at timestamp(6) NULL;ALTER TABLE public.users ADD created_by varchar(255) NULL;ALTER TABLE public.users ADD updated_by varchar(255) NULL;

4. 执行语句

5. 建表成功


6. 一些常用的Mysql简单指令

丢弃指定的数据库,如果存在的话

DROP DATABASE IF EXISTS tangdoudou;

创建新的数据库

CREATE DATABASE tangdoudou;

进入数据库tangdoudou

    USE tangdoudou;

创建表

CREATE TABLE student (sid INT, # integer 整形name VARCHAR(8), # variable character可变字符sex  VARCHAR(1), # m->男 f->女score INT);

向表中插入数据

INSERT INTO student VALUES('1','tom','F','95');

查询表中所有数据

SELECT * FROM student;

修改数据

UPDATE student SET name='lucy',score='100' WHERE sid='2';

删除数据

DELETE FROM student WHERE sid='3';

一些常用栗子:

丢弃指定的数据库tangdoudou,如果存在

DROP DATABASE IF EXISTS tangdoudou;

创建一个新的数据库

CREATE DATABASE tangdoudou;DROP DATABASE IF EXISTS tangdoudou;

进入数据库tangdoudou

USE tangdoudou;

创建保存学生数据的表(编号、姓名、性别、分数);

DROP TABLE IF EXISTS student;CREATE TABLE student (sid INT, # integer 整形name VARCHAR(8), # variable character可变字符sex  VARCHAR(1),# m->男 f->女score INT);

往学生表中插入数据

INSERT INTO student VALUES('1','tom','m','85');INSERT INTO student VALUES('2','kate','f','92');INSERT INTO student VALUES('3','king','m','74');

修改编号为2的学员成绩为100,姓名为lucy;


UPDATE student SET name='lucy' WHERE sid='2';UPDATE student SET score='100' WHERE sid='2';

删除编号为3的学员数据


DELETE FROM student WHERE sid='3';

查询学生表内容

SELECT * FROM student;

待继续补充

  • 今天就写到这里啦~小伙伴们,( ̄ω ̄( ̄ω ̄〃 ( ̄ω ̄〃)ゝ我们明天再见啦~~
  • 大家要天天开心哦

欢迎大家指出文章需要改正之处~
学无止境,合作共赢

在这里插入图片描述

欢迎路过的小哥哥小姐姐们提出更好的意见哇~~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/54481.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端实现打印1 - 使用 iframe 实现 并 分页打印

目录 打印代码对话框预览打印预览 打印代码 <!-- 打印 --> <template><el-dialogtitle"打印":visible.sync"dialogVisible"width"50%"top"7vh"append-to-bodyclose"handleClose"><div ref"print…

大数据与okcc呼叫中心融合的几种方式

在实际的生产实践中&#xff0c;为提高营销效率&#xff0c;避免骚扰大众&#xff0c;很多呼叫中心业务会与大数据平台进行合作&#xff0c;进行精准营销。 买卖数据是非法的&#xff0c;大数据平台方并不会提供直接的数据&#xff0c;一般情况下&#xff0c;提供的数据都是脱…

C#利用自定义特性以及反射,来提大型项目的开发的效率

在大型项目的开发过程中&#xff0c;需要多人协同工作&#xff0c;来加速项目完成进度。 比如一个软件有100个form&#xff0c;分给100个人来写&#xff0c;每个人完成自己的Form.cs的编写之后&#xff0c;要在Mainform调用自己写的Form。 如果按照正常的Form form1 new For…

【数据分析入门】人工智能、数据分析和深度学习是什么关系?如何快速入门 Python Pandas?

目录 一、前言二、数据分析和深度学习的区别三、人工智能四、深度学习五、Pandas六、Pandas数据结构6.1 Series - 序列6.2 DataFrame - 数据框 七、输入、输出7.1 读取/写入CSV7.2 读取/写入Excel7.3 读取和写入 SQL 查询及数据库表 八、调用帮助九、选择(这里可以参考上一篇文…

【动态规划刷题 5】 最小路径和地下城游戏

最小路径和 链接: 64. 最小路径和 给定一个包含非负整数的 m x n 网格 grid &#xff0c;请找出一条从左上角到右下角的路径&#xff0c;使得路径上的数字总和为最小。 说明&#xff1a;每次只能向下或者向右移动一步。 输入&#xff1a;grid [[1,3,1],[1,5,1],[4,2,1]] 输…

Qt--QPlugin插件

写在前面 Qt–动态链接库一文中提到&#xff0c;动态方式加载dll只能加载 extern "C“ 的导出函数&#xff0c;而无法加载类&#xff0c;因此可以使用Qt提供的插件来实现导出类的动态加载。 QPlugin是Qt插件框架的一部分&#xff0c;是一种轻量级的插件系统&#xff0c;…

数据集的介绍及其标注

水到绝境是风景 人到绝境是重生 一、什么是目标检测 目标检测是计算机视觉领域的一个重要任务&#xff0c;旨在识别和定位图像或视频中的多个目标对象。与图像分类只关注图像属于哪个类别不同&#xff0c;目标检测不仅要确定目标所属的类别&#xff0c;还要准确地标记目标在图…

STM32 DHT11

DHT11 DHT11数字温湿度传感器是一款含有已校准数字信号输出的温湿度复合传感器。 使用单总线通信 该传感器包括一个电容式感湿元件和一个NTC测温元件&#xff0c;并于一个高性能8位单片机相连&#xff08;模数转换&#xff09;。 DHT11引脚说明 开漏模式下没有输出高电平的能…

一、3.外部硬件中断与进入保护模式

外部硬件中断&#xff1a;处理器接两根线NMI传输非屏蔽中断&#xff08;即无法屏蔽的中断&#xff09;和INTR传输可屏蔽中断 IR0到IR7优先级依次降低 处理器中中断标志位起决定作用&#xff0c;IF为0时屏蔽所有INTR引脚来的信号都被屏蔽 BIOS创建中断向量表 实时时钟和CMOS RAM…

数据可视化:Matplotlib详解及实战

1 Matplotlib介绍 Matplotlib是Python中最常用的可视化工具之一,可以非常方便地创建海量类型的2D图表和一些基本的3D图表。 Matplotlib提供了一个套面向绘图对象编程的API接口&#xff0c;能够很轻松地实现各种图像的绘制&#xff0c;并且它可以配合Python GUI工具&#xff08;…

VMware Workstation下载不同的版本

1&#xff1a;访问下载链接 https://customerconnect.vmware.com/cn/downloads/#all_products 2&#xff1a;拉倒下面去选择对应的下载内容 3&#xff1a;先选择大版本 4&#xff1a;大版本选择之后&#xff0c;就可以选择对应的小版本 各位再根据自己的选择进行下载就好了

Spring Boot 单元测试

目录 1.什么是单元测试&#xff1f; 2.单元测试的优点 3.Spring Boot 单元测试使用 3.1 生成单元测试的类 3.2 添加 Spring Boot 框架测试注解&#xff1a;SpringBootTest 3.3 添加单元测试业务逻辑 3.4 注解 Transactional 4. 断言 1.什么是单元测试&#xff1f; 单元…