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

news2024/9/20 16:35:27

文章目录

    • 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) 
DO
 UPDATE
   SET 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.coloradmin.cn/o/840837.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【项目多人协作的困扰】git-cli 解决 git merge 合并时 lock 文件变化,忘记重新安装依赖的问题

项目多人协作的困扰 相信大家多多少少都遇到过,当主线分支的代码,合入到自己的分支的时候,如果这时候,主线中有一些依赖的更新或者添加或者删除,如果合入之后,没有及时的install的话,项目启动的…

力扣 -- 467. 环绕字符串中唯一的子字符串

一、题目 二、解题步骤 下面是用动态规划的思想解决这道题的过程&#xff0c;相信各位小伙伴都能看懂并且掌握这道经典的动规题目滴。 三、参考代码 class Solution { public:int findSubstringInWraproundString(string s) {int ns.size();vector<int> dp(n,1);int re…

diffusion model(六)Dalle2技术小结

Dalle2 技术小结 文章目录 Dalle2 技术小结系列阅读背景Dalle2的总体架构DiffusionPrior模块训练阶段推理阶段 DiffusionDecode 模块 Dalle2的生成质量和目前的局限性Dalle2的生成效果基于MS-COCO caption生成效果Other Dalle2的局限性 参考文献 系列阅读 diffusion model&…

Ubuntu服务器ELK部署与实践

文章目录 1. Docker安装2. 拉镜象2.1 ElastciSearch2.2 Kibana2.3 logstash 3. 数据展示 1. Docker安装 看之前的文章 docker ubuntu完全卸载docker及再次安装 Ubuntu安装 Docker 此外&#xff0c;Docker偶尔会出现这种问题dial tcp: lookup registry-1.docker.io on 192.168.1…

ICMP 理解

icmp 差错报告机制&#xff0c;tcp/ip协议族中重要的子协议&#xff0c;通常被ip层或者更高的&#xff08;tcp/udp&#xff09;使用&#xff0c;&#xff0c;属于网络层协议&#xff0c;主要用于在ip主机和路由器之间传递控制消息&#xff0c;用于报告主机是否可达、路由是否可…

融邦JAVA面试题

1. Java线程池的作用及使用方式 线程池的作用&#xff1a; (1) 降低系统资源消耗&#xff1a;通过重用已存在的线程&#xff0c;降低线程创建和销毁造成的消耗。 (2) 提高系统响应速度&#xff1a;当有任务到达时&#xff0c;无需等待新线程的创建便能立即执行。 (3) 提高线程…

SpringBoot3基础用法

技术和工具「!喜新厌旧」 一、背景 最近在一个轻量级的服务中&#xff0c;尝试了最新的技术和工具选型&#xff1b; 即SpringBoot3&#xff0c;JDK17&#xff0c;IDEA2023&#xff0c;Navicat16&#xff0c;虽然新的技术和工具都更加强大和高效&#xff0c;但是适应采坑的过程…

阿里云瑶池 PolarDB 开源官网焕新升级上线

导读近日&#xff0c;阿里云开源云原生数据库 PolarDB 官方网站全新升级上线。作为 PolarDB 开源项目与开发者、生态伙伴、用户沟通的平台&#xff0c;将以开放、共享、促进交流为宗旨&#xff0c;打造开放多元的环境&#xff0c;以实现共享共赢的目标。 立即体验全新官网&…

【测试】软件测试工具JMeter简单用法

简明扼要&#xff0c;点到为止。 1. JMeter介绍 JMeter的全称是Apache JMeter&#xff0c;是一款用于软件测试的工具软件&#xff0c;其是开源免费的&#xff0c;由Apache基金会运营。 官网&#xff1a;Apache JMeter - Apache JMeter™ 2. 下载安装及运行 2.1 安装 Java8…

RabbitMQ的6种工作模式

RabbitMQ的6种工作模式 官方文档&#xff1a; http://www.rabbitmq.com/ https://www.rabbitmq.com/getstarted.html RabbitMQ 常见的 6 种工作模式&#xff1a; 1、simple简单模式 1)、消息产生后将消息放入队列。 2)、消息的消费者监听消息队列&#xff0c;如果队列中…

深入探究Spring核心模块

&#x1f337;&#x1f341; 博主猫头虎 带您 Go to New World.✨&#x1f341; &#x1f984; 博客首页——猫头虎的博客&#x1f390; &#x1f433;《面试题大全专栏》 文章图文并茂&#x1f995;生动形象&#x1f996;简单易学&#xff01;欢迎大家来踩踩~&#x1f33a; &a…

Flowise AI:用于构建LLM流的拖放UI

推荐&#xff1a;使用NSDT场景编辑器助你快速搭建可二次编辑的3D应用场景 什么是Flowise AI&#xff1f; Flowise AI是一个开源的UI可视化工具&#xff0c;用于帮助开发LangChain应用程序。在我们详细介绍 Flowise AI 之前&#xff0c;让我们快速定义 LangChain。LangChain是…

谈谈如何使用ShellExecute的返回值

之前的一篇文章中&#xff0c;我们讲到了在 16 位 Windows 中&#xff0c;实例句柄(HINSTANCE)唯一标识了一个进程。到了 32 位 Windows&#xff0c;内核得到了完全的重新设计&#xff0c;其中之一是&#xff1a;它引入了 “内核对象” 和 “安全描述符”。 在 16 位 Windows …

vue项目实战-脑图编辑管理系统kitymind百度脑图

前言 项目为前端vue项目&#xff0c;把kitymind百度脑图整合到前端vue项目中&#xff0c;显示了脑图的绘制&#xff0c;编辑&#xff0c;到处为json&#xff0c;png&#xff0c;text等格式的功能 文章末尾有相关的代码链接&#xff0c;代码只包含前端项目&#xff0c;在原始的…

GET和POST的区别,java模拟postman发post请求

目录 一、先说一下get和post1、看一下人畜无害的w3schools怎么说&#xff1a;2、问一下文心你言哥&#xff0c;轻轻松松给你一个标准答案&#xff1a;3、卧槽&#xff0c;懂了&#xff0c;好像又没懂 二、让我们扒下GET和POST的外衣&#xff0c;坦诚相见吧&#xff01;三、我们…

MySQL5.7源码编译Debug版本

编译环境Ubuntu22.04LTS 1 官方下载MySQL源码 https://dev.mysql.com/downloads/mysql/?spma2c6h.12873639.article-detail.4.68e61a14ghILh5 2 安装基础软件 cmakeclangpkg-configperl 参考&#xff1a;https://dev.mysql.com/doc/refman/5.7/en/source-installation-prere…

网络安全进阶学习第十二课——SQL手工注入3(Access数据库)

文章目录 注入流程&#xff1a;1、判断数据库类型2、判断表名3、判断列名4、判断列数1&#xff09;判断显示位 5、判断数据长度6、爆破数据内容 注入流程&#xff1a; 判断数据库类型 ——> 判断表名 ——> 判断列名 ——> 判断列名长度 ——> 查出数据。 asp的网…

Acwing.877 扩展欧几里得算法

题目 给定n对正整数ai , bi&#xff0c;对于每对数&#xff0c;求出一组ai ,g&#xff0c;使其满足ai* xi bi * yi gcd(ai ,bi)。 输入格式 第一行包含整数n。 接下来n行&#xff0c;每行包含两个整数ai , bi。 输出格式 输出共n行&#xff0c;对于每组ai, bi&#xff0c…

hcip的ospf综合实验

题目 拓扑图 IP地址分配及环回 R1 < Huawei>sy Enter system view, return user view with CtrlZ. [Huawei]sysname r1 [r1]int g0/0/0 [r1-GigabitEthernet0/0/0]ip add 172.16.0.1 27 Aug 6 2023 19:03:33-08:00 r1 %%01IFNET/4/LINK_STATE(l)[0]:The line protocol I…

第3章 语言基础

引言 任何语言的核心所描述的都是这门语言在最基本的层面上如何工作&#xff0c;涉及语法、操作符、数据类型以及内置功能&#xff0c;在此基础之上才可以构建复杂的解决方案 本章接下来的内容主要基于ECMAScript第6版。ES6 语法 js的语法借鉴了c/c&#xff0c;java。js是相对…