文章目录

  • 一、常用的数据类型
  • 二、数据库管理
    • 1、mysql基础语句操作
      • 1.1 设置密码、登录数据库
      • 1.2 查看数据库结构
      • 1.3 查看表的结构
    • 2、DDL语句:定义数据中的操作
      • 2.1 创建数据库和表-create
      • 2.2 删除数据库和表-drop
    • 3、DML语句 :管理表中的数据记录
      • 3.1 插入数据-insert
        • 3.1.1 操作案例
      • 3.2 更新原有数据-update
      • 3.3 删除不需要的数据(表内容)-delete
    • 4、DQL语句:查询数据记录-select
    • 5、 DCL语句:数据控制语言-alter
      • 5.1 修改表名
      • 5.2、扩展表结构(增加字段)
      • 5.3 修改字段(列)名,添加唯一键
      • 5.4 删除字段
  • 三、了解约束
  • 四、总结

一、常用的数据类型

类型 解释 举例
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 查看数据库结构

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



1.3 查看表的结构

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

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表



2.2 删除数据库和表-drop

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



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);
#批量添加表中更多数据(前面的字段不写为默认)



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,地址为雨花台。**
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,'雨花台');
#插入数据(可以进行匹配插入)



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的记录进行修改。


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表中所有记录(谨慎操作)



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行)




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

5.1 修改表名

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

alter  table  ky20 rename  yyy;
alter  table  yyy  rename  ky20;

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

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


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

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

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

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

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


5.4 删除字段

alter table 表名 drop 字段名;

alter table  ky20 drop name_new;

三、了解约束

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。


四、总结

sql语言的分类

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

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

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

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

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

  • select(查看)

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

  • alter(修改字段),其中有add(添加)、change(修改)、drop(删除)

【MySql】mysql之基础语句相关推荐

  1. MySQL数据库初识(基础语句)

    初识Mysql 认知 数据库:DB所有的数据存放的仓库每一个文件夹也是数据库 数据库管理员:DBA管理数据库软件 数据库服务器:一台跑着一个数据库管理软件的机器 表:文件,一张存储了数据的表 数据/记 ...

  2. MySQL学习笔记——基础语句

    MySQL默认端口号为3306: 超级用户为root: MySQL常用命令 显示当前服务器版本:select version(); 显示当前日期时间:select now(); 显示当前用户:sele ...

  3. MySQL的一些简单语句

    mysql 统计 表的数量:SELECT COUNT(1) FROM information_schema.TABLES WHERE TABLE_SCHEMA = '你的数据库'; MySQL的一些基 ...

  4. MySQL中定义fk语句_MySQL基础篇/第3篇:MySQL基本操作语句.md · qwqoo/MySQL-Review - Gitee.com...

    ### 第3篇:MySQL基本操作语句 - MySQL基础操作 #### 排序检索数据 - 之前的数据没有进行排序,其是按照默认在数据表中的数据返回的 - SELECT语句的ORDER BY 子句进行 ...

  5. MySQL数据库test连接语句_【MySQL数据库开发之二】MySQL 基础语句的书写与操作!...

    本篇Himi简单介绍一些MySQL数据库的基础操作: 注:mysql 语句对大小写不敏感,语句以分号";"标识语句结束: 1.   首先使用两个简单的查询语句: 查询当前版本:se ...

  6. mysql 截断表_入门MySQL——基础语句篇

    前言: 前面几篇文章,我们介绍了MySQL的基础概念及逻辑架构.相信你现在应该有了自己的一套MySQL环境,接下来我们就可以开始练习MySQL了.本文将从MySQL最基础的语句出发,为你展示出创建及修 ...

  7. mysql操作语句now_【MySQL数据库开发之二】MySQL 基础语句的书写与操作!

    本篇Himi简单介绍一些MySQL数据库的基础操作: 注:mysql 语句对大小写不敏感,语句以分号";"标识语句结束: 1.   首先使用两个简单的查询语句: 查询当前版本:se ...

  8. mysql数据库基础语句讲解

    mysql数据库基础讲解 一.数据库客户端命令 二.数据库基础sql语句 三.数据表基础语句 四.数据的增删改查(重点) 切记sql语句之后一定要加 ; 一.数据库客户端命令 1.mysql: mys ...

  9. vip2-day22 MySQL 基础语句

    MySQL 8 新特性 数据字典:包含一个事务数据字典,用于储存有关数据库对象的信息.在之前的版本中,字典数据存储在元数据文件和非事务表中. 原子数据定义语句:支持原子数据定义语言(DDL). DDL ...

  10. MYSQL数据库 增删改查基础语句

    MYSQL数据库 增删改查基础语句 **********************DDL 语句 *********************   ( DDL 是数据定义语言的缩写,简单的说,就是对数据库内 ...

最新文章

  1. 一个应用在多视图光度立体视觉MVPS的NeRF方法
  2. 获取日期对应的财务期间
  3. 07.full text query_string查询
  4. Java04异常、断言、日志和调试
  5. 小伙C++代码实现短信表白,软萌甜炸,送给你最喜欢的人!你值得拥有
  6. 试着用React写项目-利用react-router解决跳转路由等问题(二)
  7. 大疆Onboard SDK开发中连接飞控后串口设置与开机自启动
  8. linux yum自动挂载_Linux系统本地Yum仓库制作
  9. UVa1587 - Box
  10. SpringMvc date数据传递处理
  11. 高效记忆/形象记忆(10)110数字编码表 41-50
  12. win7站点服务器配置,IIS 7.0安装配置方法图文教程(win7)
  13. 直流稳压稳流电源基本功能,电源使用注意事项
  14. 基于神经网络的图片风格转移小结
  15. ARCGIS中的子类型(SUBTYPE)认识
  16. Shaolin(map||set)
  17. 搭建区块链浏览器——基于hyperledger fabric 1.0,MySQL容器
  18. (个人解题思路系列)五子棋
  19. css与背景相关的属性有哪些,css的背景background的相关属性
  20. lcy mysql爆破_mysql

热门文章

  1. fst 共享后缀_FST源代码解读2——FST的生成
  2. react-native0.61插入动图无效的问题(Android)
  3. python爬取知乎神回复
  4. win10删除计算机用户,Win10电脑管理员账户删除了的解决方案
  5. 【电气专业知识问答】问:如何分析、判断与处理电流互感器二次回路开路的故障?
  6. 宽字节注入%df的理解
  7. element表格分页 + 页码不连续
  8. linux下passwd命令设置修改用户密码
  9. golang设计模式——职责链模式
  10. nx-shell 文件管理器_linux文件管理命令