当前位置: 首页 > news >正文

【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 "123456"   #给数据库设置密码(后面的回车)mysql -uroot -p "123456"   #直接登录数据库
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  ky30 (id int(10) not null,name varchar(40) not null,age int (3) not null,score decimal(5,2) default '0',primary key (id));        
#创建一个名为ky30的表,(定义id不为空,名字不为空,年龄不为空,成绩可为空默认为“0”,主键为id)create table scholl.ky31 (id int(10) not null); # 在任意库中创建school库中的ky31表

 

 2.2 删除数据库和表-drop

drop database kgc;    #删除一个名为kgc的数据库drop table ky31     #删除一个ky31的表
drop table school.ky30    #可以再别的数据库中删除指定数据库中的表

 

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

3.1 插入数据-insert

select * from ky30;     #查看ky30表中所有的数据
select * from \G;       #友好的显示insert into ky30 (id,name,age,score) values(1,'zhangsan',18,88);   
#向ky30表中插入数据insert into ky30 (id,name,age) values(2,'zhanger',18);
#向ky30表中指定字段插入,(可为空的字段,可以不添加值,为默认值)insert into ky30 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 ky30 set name='liubei',age=35 where name='zhanger';
#将字段name为zhanger的,name和age进行修改。update ky30 set name='ydq',age=24 where id>2;
#将id大于2的记录进行修改。

 没有数据库和数据表的要先创建;

delete —— 删除

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

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

select —— 查询

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

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

alter —— 修改

alter  table  ky30 rename  yyy;
alter  table  yyy  rename  ky30;

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

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

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

http://www.lryc.cn/news/149005.html

相关文章:

  • 使用API调用获取商品数据的完整方案
  • 来看看入门级别的室内设计创意是怎么样构成的
  • Go 面向对象(匿名字段)
  • 生成式AI,赋能数字劳动力的关键工具
  • python提取邮件的附件,以excel为例
  • ZooKeeper技术内幕
  • 乱糟糟的YOLOv8-detect和pose训练自己的数据集
  • 【Nginx】Nginx $remote_addr和$proxy_add_x_forwarded_for变量详解
  • MySQL自动删除binlog日志
  • C++ 文件和流
  • 案例分享:西河水库安全监测信息化系统实施方案
  • 使用Angular和MongoDB来构建具有登录功能的博客应用程序
  • ChatGPT 与前端技术实现制作大屏可视化
  • 视频监控/视频云存储EasyCVR平台接入华为ivs3800平台提示400报错,如何解决?
  • c++基础数据结构
  • 微服务-sentinel详解
  • 【MTK平台】根据kernel log分析wifi 连接的时候流程
  • 【SpringBoot】两种配置文件, 详解 properties 和 yml 的语法格式, 使用方式, 读取配置
  • 基于微信小程序的文化宣传平台的设计与实现(Java+spring boot+微信小程序+MySQL)
  • 一款windows的终端神奇,类似mac的iTem2
  • illegal cyclic inheritance involving trait Iterable_2种解决方式
  • 探秘二叉树后序遍历:从叶子到根的深度之旅
  • 2023全国大学生数学建模A题思路+模型+代码+论文(比赛开始后持续更新)
  • 从输入URL到页面展示过程:深入解析网络请求与渲染
  • Go 使用 Gorm 将操作信息集成到链路跟踪 Jaeger,进行增删改查使用举例,并做可视化UI界面展示(附源码)
  • 【JavaScript精通之道】掌握数据遍历:解锁现代化遍历方法,提升开发效率!
  • opencv android sdk 使用中的问题
  • 《向量数据库指南》——向量数据库与人工智能是一对“双生子
  • WebSocket协议
  • Spring 事务是什么 ?事务的传播机制?