• 【MySql】mysql之基础语句


    一、常用的数据类型

    类型解释举例
    int整型用于定义整数类型的数据(1、2、3、4、5…)
    float单精度浮点(4字节32位)准确表示小数点后六位
    double双精度浮点(8字节64位)小数位更多,更精确
    char固定长度的字符类型定义字符长度(存的少,会补空格,存的多被截取,高版本报错)
    varchar可变长度的字符类型定义字符最大长度(存的小,总长度变小,存的大于最大,报错)
    text文本
    image图片
    decimal(5,2)总共5个有效长度数字,小数点后面有两位

    char和varchar的区别

    • char: 如果存入数据的实际长度比指定长度要小,会补空格指指定长度,如果存入的数据的实际长度大于指定长度,低版本会被截取,高版本会报错。
    • varchar: 如果存入的数据实际长度比指定长度要小,那么指定长度会变成实际长度一样,如果存入的数据的实际长度大于指定长度,会报错。

    截取和截断的区别

    • 截取会对后一位进行四舍五入,截断直接获取要的数字,不进行四舍五入。

    二、数据库管理

    SQL语言分类

    • DDL: 数据定义语言,用于创建数据库对象,如库、表、索引等
    • DML: 数据操纵语言,用于对表中的数据进行管理
    • DQL: 数据查询语言,用于从数据表中查找符合条件的数据记录
    • DCL: 数据控制语言,用于设置或更改数据库用户或角色权限

    1、mysql基础语句操作

    1.1 设置密码、登录数据库

    mysqladmin -u root -p password "123"   #给数据库设置密码(后面的回车)
    
    mysql -uroot -p "123"   #直接登录数据库
    mysql -u root -p        #登录数据库,输入密码后完成登录
    
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    1.2 查看数据库结构

    show databases;     #查看有多少数据库(分号要加)
    use mysql           #进入一个数据库中,(分号可以不加)
    show tables;        #查看该数据库中有多少个表
    
    • 1
    • 2
    • 3

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    1.3 查看表的结构

    describe  db;     #查看表的字段属性(可缩写为desc db)
    
    • 1

    在这里插入图片描述

    2、DDL语句:定义数据中的操作

    • DDL语句可用于创建数据库对象(库、表、索引)

    • 删除数据库和表

    2.1 创建数据库和表-create

    create database school;     #创建一个名为school的数据库
    
    create table  ky20 (id int(10) not null,name varchar(40) not null,age int (3) not null,score decimal(5,2) default '0',primary key (id));        
    #创建一个名为ky20的表,(定义id不为空,名字不为空,年龄不为空,成绩可为空默认为“0”,主键为id)
    
    create table scholl.ky21 (id int(10) not null); # 在任意库中创建school库中的ky21表
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    2.2 删除数据库和表-drop

    drop database ydqmysql      #删除一个名为ydqmysql的数据库
    
    drop table ky22     #删除一个ky22的表
    drop table school.ky21    #可以再别的数据库中删除指定数据库中的表
    
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    3、DML语句 :管理表中的数据记录

    3.1 插入数据-insert

    select * from ky20;     #查看ky20表中所有的数据
    select * from \G;       #友好的显示
    
    insert into ky20 (id,name,age,score) values(1,'zhangsan',18,88);   
    #向ky20表中插入数据
    
    insert into ky20 (id,name,age) values(2,'zhanger',18);
    #向ky20表中指定字段插入,(可为空的字段,可以不添加值,为默认值)
    
    insert into ky20 values(3,'lisi',20,67),(4,'zhaowu',22,90);
    #批量添加表中更多数据(前面的字段不写为默认)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    3.1.1 操作案例

    题目:在nanjin库中创建yunjisuan这张表,要求字段为:id,name,age,score,address

    要求:①id为主键,除了address之外其它字段均不可为空,address可以为空,且模式配置为“江宁区”。(类型、长度自行定义)

    	  **②插入三条数据,zhangsan的id为1,年龄18,分数99,地址不知道;lisi的id为2,年龄为19,分数88,地址默认;wangwu的id为3,年龄17,分数为77,地址为雨花台。**
    
    • 1
    mysql> create database nanjin;   #创建库
    
    mysql> create table nanjin.yunjisuan (id int(10) not null primary key,name varchar(20) not null,age int(3) not null,score decimal(5.2) not null,address varchar(30) default '江宁区');
    #创建表(创建表的时候,需要定义表的字段结构)
    
    insert into yunjisuan values(1,'zhangsan',18,99,'不知道'),(2,'lisi',19,88,''),(3,'wangwu',17,77,'雨花台');
    #插入数据(可以进行匹配插入)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    3.2 更新原有数据-update

    update 表名 set 字段1=字段值1,字段2=字段值10 where 表达式;

    update ky20 set name='liubei',age=35 where name='zhanger';
    #将字段name为zhanger的,name和age进行修改。
    
    update ky20 set name='ydq',age=24 where id>2;
    #将id大于2的记录进行修改。
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述
    在这里插入图片描述

    3.3 删除不需要的数据(表内容)-delete

    格式:delete from 表名 where 条件表达式;

    delete from ky20 where name='ydq';   #删除ky20表中name为ydq的记录
    
    delete from ky20 where id>4;         #删除ky20表中id大于4的记录
    
    delete from ky20;                    #删除ky20表中所有记录(谨慎操作)
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    4、DQL语句:查询数据记录-select

    格式:select 字段1,字段2 from 表名 【where 条件表达式】;

    select * from ky20;           #查看整个表的所有记录
    select id,name from ky20;     #查看整个表中的id,name字段
    select id,name from ky20\G    #友好查看整个表的id,name,
    select id,name,score from ky20 where name='machao';    #查看name为machao的id,namescore
    select id,name from ky20 where score>80;    #查看分数值大于80分的字段id,name ,
    select * from ky20 limit 2;   #查看前二行
    select * from ky20 limit 2,3;    #显示第2行后的3行。(不包括第2行)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    5、 DCL语句:数据控制语言-alter

    5.1 修改表名

    aliter:修改表名称或表结构
    格式:alter table 旧表名 rename 新表名;

    alter  table  ky20 rename  yyy;
    alter  table  yyy  rename  ky20;
    
    • 1
    • 2

    在这里插入图片描述

    5.2、扩展表结构(增加字段)

    alter table  表名  add address varcghar(50) default '江宁区';
    #表示在表中增加一个字段为:address字段。
    
    • 1
    • 2

    在这里插入图片描述
    在这里插入图片描述

    5.3 修改字段(列)名,添加唯一键

    格式:alter table 表名 change 旧列名 新列名 数据类型 【unique key】;

    • unique key :唯一键(特性:唯一,但可以为空,空值只允许出现一次)

    • primary key:主键(特性:唯一且非空)

    alter table  ky20 change name name_new varchar(50) unique key;
    #change 可以修改字段名、数据类型、约束等所有项
    
    • 1
    • 2

    在这里插入图片描述
    在这里插入图片描述

    5.4 删除字段

    alter table 表名 drop 字段名;

    alter table  ky20 drop name_new;
    
    • 1

    在这里插入图片描述

    三、了解约束

    create table if not exists info (id int(4) zerofill primary key auto_increment,name varchar(10) not null,cardid int(18) not null unique key,hobby varchar(50));
    
    if not exists:表示检测要创建的表是否已存在,如果不存在就继续创建。
    int(4) zerofill:表若数值不满4位数,则前面用“0”填充,例0001。
    auto_increment: 表示此字段为自增长字段,即每条记录自动递增1,默认从1开始递增;自增长字段数据不可重复,自增长字段必须是主键,如添加的距离数据没有指定字段的值且添加失败也会自动递增一次。
    unique_key : 表示此字段唯一约束,此字段数据不可以重复,一张表中只能有一个主键,但是一张表中可以有多个唯一键。
    not null : 表示此字段不允许为NULL。
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    在这里插入图片描述
    在这里插入图片描述

    四、总结

    sql语言的分类

    DDL:数据定义语言,用于创建和删除数据库表等操作

    • create (创建)、drop(删除)

    DML:数据操纵语言,用于管理表中的记录,对数据进行增、删、改的操作

    • insert(插入)其中有into(插入)、selete(删除)、update(改)其中为set(修改)

    DQL:数据查询语言,主要用来查询数据库中的记录

    • select(查看)

    DCL:数据控制语言,用来针对字段属性的增、删、改增操作

    • alter(修改字段),其中有add(添加)、change(修改)、drop(删除)
  • 相关阅读:
    Django常用命令
    不推荐“溜溜球节食法”的10个理由
    pgpool-II 4.3 中文手册-前言
    前端三剑客 - CSS
    天翼云服务器80、443等特殊端口无法访问原因记录
    Kafka3.0.0版本——消费者(消费者组原理)
    2022测试开发面试题大全及答案(包含测试基础|接口测试|自动化测试...)【289页】
    CentOS 7安装MySQL及初始化操作教程
    Java中System.exit()方法的功能简介说明
    抓包神器之Charles(绕过代理屏蔽)以及证书校验绕过
  • 原文地址:https://blog.csdn.net/m0_57515995/article/details/126338564