zoukankan      html  css  js  c++  java
  • 数据库基本操作

    数据库:数据的集合. 特点: 高效的管理数据 数据库本身就是一种文件.
    特点:
    1.>持久化存储
    2.>读写速度极高
    3.>保证数据的有效性 防止数据错误<类型 约束>
    4.>对程序支持性非常好,容易扩展 mysql

    数据库客户端-->数据库服务器-->数据库文件文件

    数据库文件才是存储数据的,接受服务器取数据的请求

    客户端 接收用户的请求

    服务器:接收客户端请求,从数据库文件中读取数据 .提供数据服务

    DBMS:
    SQL: 就是一坨字符串,一种语法

    关系型数据库:RDBMS 通用语法是SQL

    数据库面试时最基础的,必须会手写

    关系模型:借助集合代数等数学概念. 本质上使用一张二维表来表示关系<和excel一样>

    oracle:银行,电信等项目 收费按cpu核心数计算 能够接收的客户端数量来收费

    ms旗下的sqlserver:微软

    sqlite: 轻量级

    mysql:web时代使用最广泛 提供社区版/收费版本

    横行竖列:

    数据行:记录
    数据列:字段
    数据表:整个表
    表结合表:数据库

    DB2:IBM的原创
    DQL:查询,select
    DML:操作,增加,修改,delete删除
    对于WEB程序员而言:crud:增删改查
    注意:不区分大小写 关键字是大写 只是为了区分的更清楚,给人看而已

    安装与启动:

    安装:
    服务器:
    sudo apt-get install mysql-server
    客户端:
    sudo apt-get install mysql-client
    判断服务是否启动:<最常用的>
    ps aux | grep mysql --->mysqld的服务
    或者:
    sudo service mysql status 查看状态 <最常用>
    sudo service mysql restart 重启
    sudo service mysql stop 停止
    sudo service mysql start 启动

    日志:程序的日志

    启动navicat,cd 切换到在Desktop,继续cd 进入 navicat的目录
    输入./start_navicat命令启动navicat即可.

    数据类型:

    数据类型和约束:
    数据类型:对数据的要求,影响着数据中存储的数据所占的类型约束,空间大小
    约束:数据类型之外添加额外的要求

    原则:够用就行,尽量省空间
    int:4个字节bytes
    bit<只能存一个0或者1,就是一个最小的存储空间>:表示true或者false的状态,真假,是否,存储互斥关系
    unsigned: 非负数
    1bytes=8bit
    decimal:小数,decimal(5,2),表示共存5位数,小数占2位,都是最多
    varchar:不定长 用多少给多少,但是不能超过最长的限制 varchar(3):表示最长是3个字节
    char:定长 char(32) 32个字节长度的char 张三 <6个字节> 造成空间的浪费 一般比较少用,用于手机号/身份证号等固定长度的
    图片/音频/视频/等,数据库存储对应的路径
    text字符串存储大文本,超过4000的时候推荐使用,比如技术博客
    date/time/datetime
    枚举(enum):提前把要用的都列出来,比如性别类型 {'男','女','中性',未知}
    有符号:有-号,可以表示负数
    无符号:0和整数

    smallint:表示port端口数 0-65535 的范围,刚刚好可以表示

    text:0-65535
    timestamp:时间戳 unix时间 从1970年开始计算

    选择数据类型的要求:合适的,空间最小的.

    数据类型的约束:

    约束:保证数据的完整性.必须要填的,可以不填的这种
    主键:primary key 唯一的标识 主键约束 都要有主键,mysql的 要求
    作用:唯一标识一行记录.一般都是id 自增的整数
    非空:not null 此字段不允许为空值
    唯一 unique:此字段值不允许重复 身份证号是unique的约束
    默认 default:某一个字段不填的时候,设计者自己会给这个字段填一个默认值
    如果用户没有填,使用默认值,如果填了,就使用用户填的.
    外键 foreign key: 一个表中存了另外一个表的id
    A表中的A字段使用了B表中的B字段.外键约束的含义是A字段的值必须在B字段出现过.
    A字段的值必须是B字段中的子集<不能试B字段中没有的>

    登录/退出操作:

    登录:linux里面的
    mysql -uroot -p 密码 或者 mysql -u root -p 密码 有没有空格都行,mysql会自己解析出来.
    mysql -uroot -p 在后面输入密码不会显示

    退出:这些操作是在mysql的shell界面进行操作
    exit
    quit
    Ctrl+d ---> 快捷键

    数据库操作指令/创建,使用,查看:

    数据库操作:

    1.>展示所有的数据库:show databases; 记得加s,加;分号

    2.>切换指定数据库:use + 数据库名字;

    3.>查看当前正在使用的数据库:select database(); 注意:这个是单数,database没有s

      ps: 输入指令不完全的时候继续往下输就行,系统会自己填.

    4.create database 数据库名字 charset=utf8; 千万不能在utf8中间写-,不可以是utf-8这种格式.

    如果不设置 charset,默认是另外一种格式 latin1 拉丁字符集<英文,德文,法文>,不能存储汉字类型的字符,比如日文,韩文等等.

    5.>展示创建数据库的SQL过程:show create database 数据库名字;

    6.>展示当前数据库中的所有表:show tables;

    7.>查看表结构:desc + 表名字; desc是描述describe的意思.

    8.>创建表结构的语法:
    create table 表名字(字段 类型 [约束],...); []里面的表示可选,意思就是可要可不要,看需求

    示例:
    create table studenst(
    -> id int unsigned primary key auto_increment, -->自增就保证了id 唯一unique的约束了,也保证了not null的约束了.
    -> name varchar(32) not null,
    -> age tinyint unsigned default 0 ---> 最后一个字段不要加,号
    -> ); ----> 记得加;号结束

    注意:创建表之后表中是没有数据的.

    9.>修改表结构:
    1.alter table 表名 add 字段名<就是列名> 类型 约束;-->增加一个字段
    比如: alter table student add birthday datetime not null;添加一个字段birthday,类型datetime约束是not null.
    2.alter table 表名 change 原字段名 新字段名 类型 约束;-->修改字段名称 类型 或者约束
    alter table student change birthday birth date;
    3.alter table 表名 modify 字段名 新类型 新约束;-->只修改<字段名称不修改> 类型 或者约束
    alter table student modify birth date not null;
    4.alter table 表名 drop 字段名;-->删除字段
    alter table student drop birth;

    ps:将原来的 '列名' 叫法 ---> 记得转换为叫 字段名.这些都是为了以后工作沟通方便<mysql里面列称之为字段,行称之为记录>.

    10.>展示创建数据表的SQL过程:
    show create table students;

    11.>删除表:
    drop table students;

    操作表数据:增/删/改/查

    增删改查:
    标识数据的字段顺序 加s的可以插入多行数据
    1.>增加:<插入>

    insert into 表名(字段名1,字段名2...) values/value (1,28,'Jerry'),(),(),()...

    insert into 表名(id,age,name) values/value (1,28,'Jerry'),(),(),()...

    如果 values()里面的数据顺序和字段顺序一致,可以不写字段顺序

    eg:insert into student(id,age,name) values (1,28,'Tom');
    insert into student values (1,28,'Tom');

    如果希望使用字段的默认值,使用null 或者 0<主键还可以使用自动增长> :

    insert into student(id,age,name) values (0,28,'Tom');
    insert into student(age,name) values (28,'Tom');

    ps:<id最常用,可以直接写0,默认是自增或者延续之前的字段规律>

    2.>查询:

    select * from 表名字; * 代表所有字段

    查询指定字段:
    select 字段1,字段2 from 表名字;

    3.>更新:

    update 表名字 set 字段名1=新值1,字段名2=新值2 where 条件;

    如果不写where 条件 这部分,默认是把所有行记录进行修改.那将是什么样的后果???,以后千万不要这么操作

    update studenst set name='胡松涛' where id=3;
    update studenst set name='李离扇',age=25 where id=2;

    注意:一定要加where 条件部分.

    4.>删除:

    delete from 表名 where 条件; --->物理删除

    drop table 表 ------> 表名,表结构等等全部删除

    where 是用于 挑选满足条件的 记录 (元组)

    不加条件就是全部.
    这种删除数据是很难恢复的 --->物理删除

    逻辑删除 --> 标记:在显示的时候带有标记的不显示

    本质上是更新操作.

    逻辑删除:先要添加一个字段标记is_delete,表示是否被删除:alter table studenst add is_delete bit default 0;

    实际工作中也是建议使用逻辑删除.反正删除这种操作是非常谨慎的东西,千万不要冲动.

    注意:如果设置了default 就不再需要设置not null 约束了.因为默认值存在,就不会有空值了.

  • 相关阅读:
    Quartz任务调度系统,克隆表达式
    Java故障分析基础
    SpringData JPA整理
    Mockito教程
    SpringMVC单元测试-MockMvc
    SpringBoot Actuator & SpringBoot Admin
    Swagger
    Spring @AliasFor
    java命令查询属性信息
    windows版本免安装redis, nginx, zookeeper
  • 原文地址:https://www.cnblogs.com/huaibin/p/12100431.html
Copyright © 2011-2022 走看看