MySQL从入门到精通(二)数据库和表的基础操作

1. 启动服务和登陆mysql

启动服务

net start mysql<服务名>

停止服务

net stop mysql<服务名>

查看mysql版本

mysqladmin --version

登陆数据库

mysql -u root<用户名> -p

退出数据库

exit或quit

数据目录

datadir="C:/ProgramData/MySQL/MySQL Server 5.7/Data/"

2. 数据库基本操作

2.1 创建数据库

创建数据库

create database test_db

创建数据库,判断不存在,再创建

create database if not exists test_db

创建数据库并指定字符集

create database test_db character set UTF-8
2.2 查询数据库

查询所有数据库名称

show databases

查询某个数据库

show create database test_db
2.3 修改数据库

修改数据库的字符集

 alter database test_db character set UTF8;
2.4 删除数据库

删除数据库

drop database test_db

判断数据库存在,存在再删除

drop database if exists test_db
2.5 使用数据库

查询当前使用的数据库

select database()

使用数据库

use test_db

3. 表的基本操作

3.1 创建表
create table <表名>(
字段名1 数据类型 [列级别约束条件] [默认值],
字段名2 数据类型 [列级别约束条件] [默认值],
......
[表级别约束条件]
//注:最后一行不需要逗号“,"
);

关于约束和数据库数据类型,后面再讲

例子

 create table tb_empl(
    -> id int(11),
    -> name varchar(25),
    -> depId int(11),
    -> salary float
    -> );

设置表的属性自动增加

 create table tb_empl(
    -> id int(11) primary key auto_increment,
    -> name varchar(25),
    -> depId int(11),
    -> salary float
    -> );
3.2 查询表

查询某个数据库中所有的表

show tables

查询某个表的数据结构

desc <表名>

查看某个表的详细信息

show create table <表名>
3.3 修改表

修改表名

 alter table oldName rename [to] newName;

修改字段的数据类型

alter table <表名> modify <字段名> <数据类型>;

修改字段名

alter table <表名> change <旧字段> <新字段名> <新数据类型>;

添加字段

alter table <表名> add <新字段名> <数据类型> [约束条件] [first|after 已存在的字段名]

① 添加无完整性约束条件的字段

 alter table tb_empl add phone varchar(32);

② 添加有完整性约束条件的字段

alter table tb_empl phone varchar(32) not null;

③ 在表的第一列添加一个字段

 alter table tb_empl add phone varchar(varchar) first;

④ 在表的制定列之后添加一个字段

alter table tb_empl add phone varchar(32) after name;

删除字段

 alter table <表名> drop <列名>

修改字段的排列位置

alter table <表名> modify <字段1> <数据类型> first|after <字段2>

① 修改字段为表的第一列

  alter table tb_empl modify name  first;

② 修改字段到表的指定列之后

 alter table tb_empl modify name varchar(32) after no;

更改表的存储引擎

alter table <表名> engine=<修改后的引擎名>;

删除表的外键约束

alter table <表名> drop foreign key <外键约束名>

修改字符集

alter table <表名> character set <字符集名称>;
3.4 删除表

删除没有被关联的表

drop table [if exists] 表1,表2,...表n;

删除被其它表关联的主表

数据表之间存在外键关联的情况下,如果直接删除父表,结果会显示失败,原因是直接删除,将破坏表的参照的完整性,如果必须要删除,有以下两种方法:

① 先删除子表,再删除父表,如果要保留子表,可以用下面的方法

② 将关联表的外键约束取消

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值