1.数据库表的创建

逻辑库

1)创建逻辑库:CREATE DATABASE 逻辑库名称;
2)显示逻辑库:SHOW DATABASES;
3)删除逻辑库:DROP DATABASE 逻辑库名称;

数据表

1)显示逻辑库有哪些表:SHOW TABLES;
2)查看student表具体信息:DESC student;
3)查看当时创建student表的SQL:SHOW CREATE TABLE student;
4)删除student表:DROP TABLE student;
5)创建数据表(中括号内容非必须项):
CREATE TABLE 数据表(
列名1 数据类型 【约束】 【COMMENT 注释】,
列名2 数据类型 【约束】 【COMMENT 注释】,
......
)【COMMENT=注释】; #实例:
#UNSIGNED :不带-号的整数; PRIMARY KEY 主键
use test;
CREATE TABLE student(
id INT UNSIGNED PRIMARY KEY,
name VARCHAR(20) NOT NULL,
sex CHAR(1) NOT NULL,
birthday DATE NOT NULL,
tel CHAR(11) NOT NULL,
remark VARCHAR(200)
); #插入数据校验
INSERT INTO student VALUES(1,'张三','男','2000-02-22','11111111111',NULL);
6)数据表添加字段:
ALTER TABLE 表名称
ADD 列1 数据类型 【约束】 【COMMENT 注释】,
ADD 列1 数据类型 【约束】 【COMMENT 注释】,
……;

#实例:
ALTER TABLE student
ADD address VARCHAR(200) NOT NULL,
ADD home_tel CHAR(11) NOT NULL;
7)修改表字段类型和约束
ALTER TABLE 表名称
MODIFY 列1 数据类型 【约束】【COMMENT 注释】,
MODIFY 列2 数据类型 【约束】【COMMENT 注释】,
……;

#实例
ALTER TABLE student
MODIFY home_tel VARCHAR(20) NOT NULL; DESC student;#查看表信息,核对字段是否已修改过来
8)修改表字段名称
ALTER TABLE 表名称
CHANGE 列1 新列名1 数据类型 【约束】【COMMENT 注释】,
CHANGE 列2 新列名2 数据类型 【约束】【COMMENT 注释】,
……;

#实例
ALTER TABLE student
CHANGE address home_address VARCHAR(200) NOT NULL; DESC student;#查看表信息,核对字段是否已修改过来
9)表删除字段
ALTER TABLE 表名称
DROP 列1,
DROP 列2,
……; #实例
ALTER TABLE student
DROP home_address,
DROP home_tel; DESC student;#查看表信息,核对字段是否已修改过来

2.不同的数据类型


3.数据库表字段约束

前置知识

设计数据表要符合第三范式,下面是字段约束的讲解

CREATE TABLE t_teacher(
id INT UNSIGNED PRIMARY KEY AUTO_INCREMENT, #int类型,不能取负整数(UNSIGNED),约束条件:主键约束(PRIMARY KEY),id自增(AUTO_INCREMENT)
name VARCHAR(20) NOT NULL, #约束条件:非空约束(NOT NULL)
tel CHAR(11) NOT NULL UNIQUE, #约束条件:非空约束(NOT NULL),唯一约束(UNIQUE)
married BOOLEAN NOT NULL DEFAULT FALSE #约束条件:非空约束(NOT NULL),默认值为FALSE(DEFAULT FALSE)

#父表;
CREATE TABLE t_dept(
deptno INT UNSIGNED PRIMARY KEY,
dname VARCHAR(20) NOT NULL UNIQUE,
tel CHAR(4) UNIQUE
); #子表
CREATE TABLE t_emp(
empno INT UNSIGNED PRIMARY KEY,
ename VARCHAR(20) NOT NULL,
sex ENUM("男","女") NOT NULL,
deptno INT UNSIGNED,
hiredate DATE NOT NULL,
FOREIGN KEY (deptno) REFERENCES t_dept(deptno) #外键约束
);


4.数据库的索引机制

查看数据表有哪些索引

SHOW INDEX FROM 表名;

创建数据表同时创建索引

CREATE TABLE(
......,
INDEX [索引名称] (字段), #[索引名称]不填时,索引名称默认就是字段名称
......
); #实例
CREATE TABLE t_message(
id INT UNSIGNED PRIMARY KEY,
content VARCHAR(200) NOT NULL,
type ENUM("公告","通知","个人通知"),
create_time TIMESTAMP NOT NULL,
INDEX idx_type (type)
);

数据表已经存在,添加索引

#方式一
CREATE INDEX 索引名称 ON 表名(字段); #方式二
ALTER TABLE 表名称 ADD INDEX [索引名](字段);

数据表已经存在,删除索引

DROP INDEX 索引名称 ON 表名;
DROP INDEX idx_type ON t_message;
CREATE INDEX idx_type ON t_message(type);
SHOW INDEX FROM t_message;


5.MySQL中的相似方法

5.1.DESC和SHOW CREATE TABLE的区别

  • DESC 表名:用来显示表的状态,包括列名(column name),各个列的类型(Type),各个列的值类型,主外键(Key),默认值等;

  • SHOW CREATE TABLE 表名:显示创建表时的sql语句

5.2.MODIFY和CHANGE的区别

  • CHANGE可以重命名列名,也可以修改列的数据类型,而MODIFY只能修改列的数据类型。
  • 在使用CHANGE修改数据类型时,CHANGE语法要写原列名称和新列名称,即使原列名称和新列名称是一样的。这种情况下就可以使用MODIFY来改变列的数据类型,不需要重命名。

5.3.TIME和TIMESTAMP的区别

  • TIME是存储一天的时间:时分秒
  • TIMESTAMP既有日期也有时间,但是保存的时间只能是1970-1-1日之后的,在数据库中存储格式如下图所示:

5.4. CHAR和VARCHAR的区别

  • CHAR存储定长数据很方便,比如定义CHAR (10),那么不论你存储的数据是否达到了10个字节,都要占去10个字节的空间
  • VARCHAR存储变长数据,若一个字段值是不固定长度的,我们只知道它不可能超过10个字符,把它定义为 VARCHAR (10)是最合适的。VARCHAR类型的实际长度是它的值的实际长度+1。所加的1字节就是为了存储实际使用了多大的长度

MySQL(3) - 数据库表的相关操作的更多相关文章

  1. 对mysql数据库表的相关操作

    虫师博客(Python使用MySQL数据库(新)): https://www.cnblogs.com/fnng/p/3565912.html 1.更改表的结构,增加一个字段放置新增的属性 alter ...

  2. MySQL(三) 数据库表的查询操作【重要】

    序言 1.MySQL表操作(创建表,查询表结构,更改表字段等), 2.MySQL的数据类型(CHAR.VARCHAR.BLOB,等), 本节比较重要,对数据表数据进行查询操作,其中可能大家不熟悉的就对 ...

  3. MySQL创建数据库/表等基本命令操作

    前提:安装好MySQL并且配置好服务,能够正常使用 按住键盘上的Windows图标,通过搜索框找到MySQL5.7 Command Line Client,点击启动 输入安装时设置用户的密码 成功连接 ...

  4. day40数据库之表的相关操作

    数据库之表的相关操作1.表的操作: 1.创建表的语法:        create table 表名(              id   int(10)   primary key auto_inc ...

  5. mysql(三) 数据表的基本操作操作

    mysql(三) 数据表的基本操作操作 创建表,曾删改查,主键,外键,基本数据类型. 1. 创建表 create table 表名( 列名 类型 是否可以为空, 列名 类型 是否可以为空 )ENGIN ...

  6. MySQL更改数据库表的存储引擎

    MySQL更改数据库表的存储引擎 1.查看表的原存储引擎 show create table user; 'user', 'CREATE TABLE `user` (\n `id` int(11) N ...

  7. MySQL查看数据库表容量大小

    本文介绍MySQL查看数据库表容量大小的命令语句,提供完整查询语句及实例,方便大家学习使用. 1.查看所有数据库容量大小 select table_schema as '数据库', sum(table ...

  8. MySQL中将数据库表名修改成大写的存储过程

    原文:MySQL中将数据库表名修改成大写的存储过程 MySQL中将数据库表名修改成大写的存储过程 创建存储过程的代码: DROP PROCEDURE IF EXISTS uppercaseTablen ...

  9. MYSQL--表与表之间的关系、修改表的相关操作

    表与表之间的操作: 如果所有信息都在一张表中: 1.表的结构不清晰 2.浪费硬盘空间 3.表的扩展性变得极差(致命的缺点) 确立表与表之间的关系.一定要换位思考(必须在两者考虑清楚之后才能得出结论) ...

随机推荐

  1. ZAB 和 Paxos 算法的联系与区别?

    相同点: 1.两者都存在一个类似于 Leader 进程的角色,由其负责协调多个 Follower 进程的运行 2.Leader 进程都会等待超过半数的 Follower 做出正确的反馈后,才会将一个提 ...

  2. 当一个线程进入一个对象的 synchronized 方法 A 之后, 其它线程是否可进入此对象的 synchronized 方法 B?

    不能.其它线程只能访问该对象的非同步方法,同步方法则不能进入.因为非静 态方法上的 synchronized 修饰符要求执行方法时要获得对象的锁,如果已经进入 A 方法说明对象锁已经被取走,那么试图进 ...

  3. Memcached 服务特点及工作原理是什么?

    a.完全基于内存缓存的 b.节点之间相互独立 c.C/S 模式架构,C 语言编写,总共 2000 行代码. d.异步I/O 模型,使用 libevent 作为事件通知机制. e.被缓存的数据以 key ...

  4. runnable 和 callable 有什么区别

    callable 有返回值,并允许抛出异常 runnable 没有返回值,不会抛出异常

  5. 学习GlusterFS(九)

    环境说明: 3台机器安装 GlusterFS 组成一个集群. 使用 docker volume plugin GlusterFS 服务器: 10.6.0.140 10.6.0.192 10.6.0.1 ...

  6. MySQL优化篇(一),我可以和面试官多聊几句吗?——SQL优化流程与优化数据库对象

    我可以和面试官多聊几句吗?只是想偷点技能过来.MySQL优化篇(基于MySQL8.0测试验证),上部分:优化SQL语句.数据库对象,MyISAM表锁和InnoDB锁问题. MyISAM表锁和InnoD ...

  7. Spring 和 SpringMVC 常用注解和配置(@Autowired、@Resource、@Component、@Repository、@Service、@Controller的区别)

    Spring 常用注解 总结内容 一.Spring部分 1.声明bean的注解 2.注入bean的注解 3.java配置类相关注解 4.切面(AOP)相关注解 5.事务注解 6.@Bean的属性支持 ...

  8. CCS基础样式表

    一.css样式表 1.样式表分类 1.内联式 <p >This is an apple</p> 2.内嵌样式表 作为一个独立的区域 内嵌在网页里面,必须写在head标签里面 & ...

  9. SpringMVC 解析(四)编程式路由

    多数情况下,我们在使用Spring的Controller时,会使用@RequestMapping的形式把请求按照URL路由到指定方法上.Spring还提供了一种编程的方式去实现请求和路由方法之间的路由 ...

  10. [ Vim ] 自动重载文件

    https://www.cnblogs.com/yeungchie/ 手动重载 :e 或者 :! 自动重载 set autoread 一般情况下,vim 切换缓冲区或者重新聚焦的时候会触发重载. 如果 ...