zoukankan      html  css  js  c++  java
  • MySQL-数据表操作

    1.打开数据库

    语法:USE 数据库名称;
    SELECT DATABASE();---查询当前使用的数据库

    2.创建数据表

    语法:CREATE TABLE [IF NOT EXITS] table_name(
    column_name data_type,
    ...
    )

    3.查看数据表

    语法:SHOW TABLES;

    4.查看数据表结构

    语法:SHOW COLUMNS FROM tbl_name;---查询表的列结构

    4.数据表插入记录

    语法:
    INSERT [INTO] tbl_name [(col_name,...)] VALUES (VAL,...)
    说明:.如果省略列名,则需要给每列都要赋值!
    .可以只给部分字段插入值,通过指定要插入的字段即可。
    .对float型,如果插入值的小数点位数大于实际定义位数,可以插入成功,只是截取定义的位数。
    查看数据表内容:
    SELECT expr FROM tbl_name;
    注意:常用的SELECT * FROM tbl_name,不是查询所有记录,而是指查询所有字段。

    5.数据表数据的更新

    UPDATE TABLE tableName SET field1=newValue1,field2=newValue2,...
    [WHERE clause]

    6.数据表数据的删除

    DELETE FROM TABLE tableName [WHERE Clause]
    说明:DML语句即是对数据表中数据的操作语句,是指INSERT,UPDATE,DELETE

    7.SELECT *与SELECT 所有字段差异

    .特别注意:两者的查询效率是一样的;
    .建议使用后者,主要是考虑到数据库代码的可阅读性,特别是其他人来维护代码时,后者更容易让其他人了解数据表的字段!

    8.幂等性

    8.1概念

    一个幂等操作的特点是其任意多次执行所产生的影响均与一次执行的影响相同。
    幂等函数,或幂等方法,是指可以使用相同参数重复执行,并能获得相同结果的函数。

    8.2实际的幂等技术方法

    1.查询操作 查询一次和查询多次,在数据不变的情况下,查询结果是一样的。select是天然的幂等操作。

    1. 删除操作 删除操作也是幂等的,删除一次和多次删除都是把数据删除。(注意可能返回结果不一样,删除的数据不存在,返回0,删除的数据多条,返回结果多个)

    3.唯一索引,防止新增脏数据 比如:支付宝的资金账户,支付宝也有用户账户,每个用户只能有一个资金账户,怎么防止给用户创建资金账户多个,那么给资金账户表中的用户ID加唯一索引,所以一个用户新增成功一个资金账户记录

    要点: 唯一索引或唯一组合索引来防止新增数据存在脏数据 (当表存在唯一索引,并发时新增报错时,再查询一次就可以了,数据应该已经存在了,返回结果即可)

    1. token机制,防止页面重复提交

    业务要求:页面的数据只能被点击提交一次

    发生原因:由于重复点击或者网络重发,或者nginx重发等情况会导致数据被重复提交

    解决办法:集群环境:采用token加redis(redis单线程的,处理需要排队) 单JVM环境:采用token加redis或token加jvm内存。
    处理流程:
    数据提交前要向服务的申请token,token放到redis或jvm内存,token有效时间
    提交后后台校验token,同时删除token,生成新的token返回
    token特点:要申请,一次有效性,可以限流

    注意:redis要用删除操作来判断token,删除成功代表token校验通过,如果用select+delete来校验token,存在并发问题,不建议使用。
    5. 悲观锁 获取数据的时候加锁获取

    select * from table_xxx where id='xxx' for update;

    注意:id字段一定是主键或者唯一索引,不然是锁表,会死人的

    悲观锁使用时一般伴随事务一起使用,数据锁定时间可能会很长,根据实际情况选用

    1. 乐观锁 乐观锁只是在更新数据那一刻锁表,其他时间不锁表,所以相对于悲观锁,效率更高。

    乐观锁的实现方式多种多样可以通过version或者其他状态条件:

    1、通过版本号实现

    update table_xxx set name=#name#,version=version+1 where version=#version#

    2、通过条件限制
    update tablexxx set name=#name#,version=version+1 where id=#id# and version=#version#

    update tablexxx set avaiamount=avaiamount-#subAmount# where id=#id# and avai_amount-#subAmount# >= 0
    注意:乐观锁的更新操作,最好用主键或者唯一索引来更新,这样是行锁,否则更新时会锁表

    参考:https://zhuanlan.zhihu.com/p/99922970?from_voters_page=true

  • 相关阅读:
    SpringBoot项目启动Gzip压缩
    Docker学习(一)
    MySQL中text类型说明
    java MultipartFile多文件上传/通过文件夹解析所有文件
    java后端处理跨域
    SpringCloud Feign调用服务接口时,GET请求变成POST请求报错
    java8 LocalDateTime/LocalDate 获取各种日期类型
    IDEA 不能输入中文
    基于docker 搭建minio 文件服务器
    MySql数据库导入sql错误 Unknown collation: 'utf8mb4_0900_ai_ci'
  • 原文地址:https://www.cnblogs.com/dLarger/p/12917099.html
Copyright © 2011-2022 走看看