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

Mysql基本使用语句(一)

一、登陆mysql查询数据库并创建一张表

1.1、mysql 登陆连接服务器
sudo mysql -uroot -p
1.2、查询已存在的数据库
show databases;

1.3、创建一个数据库
create databases d2;

1.4、使用一个数据库,并查询当前所用的数据库
use d2;//使用u2数据库
select database();//查询当前所用的数据库

1.5、往d2数据库里添加一张名为学生的表,包括学生名字为可变成字符串类型、id为无符号整形且设为主键且自动增长、电话号码为可变长字符串类型且不能为空;
create table student(name varchar(10),id int unsigned primary key auto_increment,phone varchar(20) not null );

查看当前有哪些表,并查看学生表的数据类型:

show tables;
desc student;

查看这张表的创建细节:

show create table student \G;

1.6、往表里添加学生信息:姓名为:张三,学号为1234,手机号码为12345678901;
insert into student values('张三',1234,'12345678901');

查询插入后的数据:

select *from student;

二、对表的增删改

2.1、增加一列班级信息,属性为varchar类型,且不能为空,默认为一班,并添加备注信息;
 alter table student add class varchar(10) not null default '一班' comment '默认为一班';

查询更改后的表属性:

desc student;

往表里添加一行学生信息:名字:李四,id:1235,电话:'12345678902', 班级:不设置;

insert into student(name,id,phone) values('李四',1235,'12345678902');

查看插入后效果:

2.2 、修改class列名为address,类型为固定字符类型:
alter table student change class address char(30);

查询修改后的效果:

2.3、更新张三、李四的地址为'广州'和 '北京':
update student set address ='广州' where name='张三';
 update student set address='北京' where name='李四';

查询更新后的结果:

2.4、删除一行信息
 delete from student where name='张三';

查询删除后的效果:

2.5、删除一列信息
 alter table student drop phone;

删除后的效果:

2.6、删除整个表
drop table student;

删除后的效果:

三、表的约束

3.1、表的主键

什么是主键:用来唯一的约束该字段里的数据,不能重复,不能为空,一张表中最多一个主键,主键所在列通常是整数类型;

3.2、创建表时添加主键:关键字:primary key
 create table student(id int unsigned primary key,name varchar(30) not null,class varchar(20) not null);

查看创建好的表的属性:

查看表创建时的细节:

往表里插入数据时id不能为空,不能重复:

当输入为空时:

正常插入:

当插入id重复时:

3.3、去掉主键
 alter table student drop primary key;

查询去掉后的效果:

查看当前表信息:

插入重复id:

insert into student values(1,'李四','二班');

查询当前表信息:

重复id被插入:

3.4、自增长主键

创建一个学生表并把id设为自增长主键:

create table student(id int primary key auto_increment,name varchar(30));

查看表属性:

向表中插入数据时,id会自增长:

3.5、唯一键

主键与唯一键相互补充,不冲突,唯一键可以为空,唯一键不能重复;

修改前表属性:

设置学生名为唯一键:

alter table student add unique (name);

查询修改后表属性:

查看当前表:

当插入相同名字时:

插入其他名字:

3.6、外键

主要强调表跟表之间的关联,表跟表之间的约束!

学生表信息:

班级表信息:

设置学生表中的classid为外键,跟班级表中的id产生关联,其中学生表为从表,班级表为主表:

 alter table student add constraint fk_student_class foreign key(id) references class(id);

当删除class表中的'土木工程'列时:

无法删除,因为student 中存在与class表关联的外键,要先把student中的关联的外键行先删掉,也就是先把所有土木工程的学生先删掉:

此时再把'土木工程删掉':

同理,相反,当往student里插入数据时,如果在class表里面没有出现过的id也一样无法插入

查看当前student表、class表:

只有在class表中与之关联的主键出现过的id才能插入:

今天分享到这里,如果对你有所帮助记得点赞收藏+关注哦!!谢谢!!!

咱下期见!!!

http://www.dtcms.com/a/331439.html

相关文章:

  • [激光原理与应用-271]:理论 - 波动光学 - 电磁波谱,光是一种可视化的电磁波
  • 广义矩估计随机近似中1.2和2.1的差异
  • 获取iframe中canvas画面
  • 爬虫数据存储全攻略:从 Robots 协议到文件存储
  • C++11新特性深度解析
  • Linux软件下载菜单脚本
  • Effective C++ 条款41:理解隐式接口和编译期多态
  • 系统设计——DDD领域模型驱动实践
  • 深入浅出词向量(Word2Vec):从理论到实践
  • 数据结构初阶(13)排序算法-选择排序(选择排序、堆排序)(动图演示)
  • 【Java 后端】Spring Boot 集成 JPA 全攻略
  • HTTPS 工作原理
  • 电池充放电测试仪厂家:技术深耕与场景驱动的行业进阶
  • Java使用Apache POI读取Excel文件
  • Vue浅学
  • 深入解析 GitHub Actions 工作流文件编写:从入门到实战
  • 简单的 HTTPS 学习
  • 第四天-创建一个Classic CAN(经典CAN2.0)/CANFD的系统描述ARXML文件
  • 读From GPT-2 to gpt-oss: Analyzing the Architectural Advances
  • IPv6互联网地址解析
  • 从合规到卓越:全星QMS如何成为制造企业的质量战略引擎
  • linux 软硬链接详解
  • 《算法导论》第 25 章:所有结点对的最短路径问题
  • 计算机视觉CS231n学习(8)
  • 12 ABP Framework 租户管理
  • 介绍一下 自动驾驶 感知多任务训练模型设计
  • 面试题:如何用Flink实时计算QPS
  • 第4节 神经网络从公式简化到卷积神经网络(CNN)的进化之路
  • 第三章、GRU(门控循环网络,Gated Recurrent Unit)
  • redis中分布式锁的应用