数据库和表的基本操作

数据库基础知识

创建数据库

CREATE DATABASE 数据库名称 ;

查看数据库(显示数据库名列表)

SHOW DATABASES ;

查看某数据库信息(显示创建的信息)

SHOW CREATE DATABASE 数据库名称 ;

修改数据库编码

ALTER DATABASE 数据库名称
DEFAULT CHARACTER SET 编码方式 COLLATE 编码方式_bin ;

删除数据库

DROP DATABASE 数据库名称 ;

数据类型

整数类型
数据类型 字节数 无符号数取值范围 有符号数取值范围
TINYINT 1 0~255 -128~127
SAMLLINT 2 0~65535 -32768~32767
MEDIUMINT 3 0~16777215 -8388608~8388607
INT 4 0~4294967295 -2147483648~2147483647
BIGINT 5 0~18446744073709551615 -9223372036854775808~9223372036854775807
浮点数类型和定点数类型

单精度浮点数类型FLOAT,4字节;

双精度浮点类型DOUBLE,8字节;

定点数类型DECIMAL(D,B),M+2字节,M表示数据的长度,D表示小数点后的长度。

日期与时间类型
数据类型 字节数 取值范围 日期格式 零值 补充
YEAR 1 1901~2155 YYYY 0000 字符串格式'0'表示2000,数字格式0表示0000
DATE 4 1000-01-01 YYYY-MM-DD 0000-00-00 使用CURRENT_DATE或者NOW()表示当前系统日期
TIME 3 -838:59:59~838:59:59 HH:MM:SS 00:00:00 可以输如'D HH:MM:SS'字符串,D表示0~34之间的值,相当于D*24+HH .使用CURRENT_DATE或者NOW()表示当前系统日期
DATETIME 8 1000-01-01 00:00:00~9999-12-31 23:59:59 YYYY-MM-DD HH:MM:SS 0000-00-00 00:00:00 使用NOW()表示当前系统日期
TIMESTAMP 4 1970-01-01 00:00:01~2038-01-19 03:14:07 YYYY-MM-DD HH:MM:SS 0000-00-00 00:00:00 使用CURRENT_TIMESTAMP来输入当前系统日期;输入NULL时系统会输入系统当前日期和时间;无任何输入时,系统会输入系统当前日期和时间。
字符串和二进制类型
数据类型 类型说明 补充
CHAR 用于表示固定长度的字符串
VARCHAR 用于表示可变长度的字符串
BINARY 用于表示固定长度的二进制数据
VARBINARY 用于表示固定长度的二进制数据
BLOB 用于表示二进制大数据
TEXT 用于表示大文本数据
ENUM 表示枚举类型,只能存储一个枚举字符串值
SET 表示字符串对象,可以有零或多个值
BIT 表示位字段类型

数据表的基本操作

选择数据库

USE 数据库名 ;

创建数据表

CREATE TABLE 数据表名
(
字段名1 数据类型[完整性约束条件] ,
字段名2 数据类型[完整性约束条件] ,
...
字段名n 数据类型[完整性约束条件]
) ;

查看此数据库下的表(显示表名列表)

SHOW TABLES ;

查看数据表(显示定义语句,字符编码)

SHOW CREATE TABLE 表名 ;

整齐的查看数据表(显示定义语句,字符编码)

SHOW CREATE TABLE 表名\G

查看数据表(显示字段信息)

DESCRIBE 表名 ;

或简写为:

DESC 表名 ;

执行结果如下:

+----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id | int(20) | YES | | NULL | |
| grade | float | YES | | NULL | |
| username | varchar(10) | YES | | NULL | |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

(1).NULL:表示该列是否可以存储NULL值;

(2).Key:表示该列是否已经编制索引;

(3).Default:表示该列是否有默认值;

(4).Extra:表示获取到的与给定列相关的附加信息。

修改表名(to可以省略)

ALTER TABLE 旧表名
RENAME [To] 新表名 ;

修改字段名

ALTER TABLE 表名
CHANGE 旧字段名 新字段名 新数据类型 ;

修改字段的数据类型

ALTER TABLE 表名
MODIFY 字段名 数据类型 ;

添加字段

ALTER TABLE 表名
ADD 新字段名 数据类型
[约束条件][FIRST | AFTER 已存在字段名]

上述格式中,“FIRST”为可选参数,用于将新加字段设为第一个字段,“AFTER”也为可选参数,用于将新加字段添加到指定“已存在字段名”的后面。

修改字段的排列位置

修改为第一个字段:

ALTER TABLE 表名
MODIFY 字段名1 数据类型 FIRST;

将字段名1插入到字段名2之后:

ALTER TABLE 表名
MODIFY 字段名1 数据类型 AFTER 字段名2 ;

删除字段

ALTER TABLE 表名
DROP 字段名 ;

删除数据表

DROP TABLE 表名 ;

表的约束

约束条件 说明
PRIMARY KEY 主键约束,用于唯一标识对应的记录
FOREIGN KEY 外键约束
NOT NULL 非空约束
UNIQUE 唯一性约束
DEFAULT 默认值约束,用于设置字段的默认值
AUTO_INCREMENT 字段值自动增加

举个例子:

id为主键且值自动增加,name字段值唯一,grade字段默认值为0。

CREATE TABLE TB_GRADE
(
id INT(10) PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(20) UNIQUE,
grade FLOAT DEFAULT 0
);

索引

创建表的时候创建索引
CREATE TABLE 表名
(
字段名 数据类型[完整性约束条件] ,
字段名 数据类型[完整性约束条件] ,
...
字段名 数据类型[完整性约束条件] ,
[ UNIQUE | FULLTEXT | SPATIAL ] INDEX | KEY
[ 别名 ] (字段名1 [ (长度)] [ ASC | DESC] )
) ;

上述相关语法解释:

(1)UNIQUE:可选参数,表示唯一索引。

(2)FULLTEXT:可选参数,表示全文索引。

(3)SPATIAL:可选参数,表示空间索引。

(4)INDEX和KEY:用来表示字段的索引,二者选一即可。

(5)别名:可选参数,表示创建的索引名称。

(6)字段名1:指定索引对应字段的名称(创建多列索引时,用逗号隔开)。

(7)长度:可选参数,用于表示索引的长度。

(8)ASC和DESC:可选参数,ASC代表升序排列,DESC代表降序排列。

在已经存在的表上创建索引

方法一:

CREATE [ UNIQUE | FULLTEXT | SPATIAL ] INDEX 索引名
ON 表名 (字段名1 [ (长度)] [ ASC | DESC] ) ;

方法二:

ALTER TABLE 表名
ADD [ UNIQUE | FULLTEXT | SPATIAL ] INDEX 索引名 (字段名1 [ (长度)] [ ASC | DESC] ) ;
删除索引

方法一:

ALTER TABLE 表名
DROP INDEX 索引名 ;

方法二:

DROP INDEX 索引名
ON 表名 ;

MySQL-数据库和表的基本操作的更多相关文章

  1. Mariadb/MySQL数据库单表查询基本操作及DML语句

    Mariadb/MySQL数据库单表查询基本操作及DML语句 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一数据库及表相关概述 1>.数据库操作 创建数据库: CREATE ...

  2. MySQL<数据库和表的基本操作>

    数据库和表的基本操作 数据库基础知识 创建数据库 就是在数据库系统中划分一块存储数据的空间 CREATE DATABASE itcast; 查看数据库 SHOW CREATE DATABASE 数据库 ...

  3. MySQL : 数据库和表的基本操作总结

    针对database和table的操作大致可分为三类:创建,查询,修改,删除 1. 创建 create ①创建数据库 create database db_name; ②创建表 create tabl ...

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

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

  5. MySQL数据库以及表的管理

    MySQL数据库以及表的管理 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 今天我们探讨的话题就是如何使用MySQL做开发,我们运维的主要工作不是去开发SQL的,但尽管如此,我们有 ...

  6. MySQL数据库分表的3种方法

    原文地址:MySQL数据库分表的3种方法作者:dreamboycx 一,先说一下为什么要分表 当一张的数据达到几百万时,你查询一次所花的时间会变多,如果有联合查询的话,我想有可能会死在那儿了.分表的目 ...

  7. mysql数据库单表只有一个主键自增id字段,ibatis实现id自增

    mysql数据库单表只有一个主键自增id字段,ibatis实现id自增 <insert id="autoid">        insert into user_id ...

  8. Vc数据库编程基础MySql数据库的表查询功能

    Vc数据库编程基础MySql数据库的表查询功能 一丶简介 不管是任何数据库.都会有查询功能.而且是很重要的功能.上一讲知识简单的讲解了表的查询所有. 那么这次我们需要掌握的则是. 1.使用select ...

  9. Vc数据库编程基础MySql数据库的表增删改查数据

    Vc数据库编程基础MySql数据库的表增删改查数据 一丶表操作命令 1.查看表中所有数据 select * from 表名 2.为表中所有的字段添加数据 insert into 表名( 字段1,字段2 ...

  10. mysql数据库user表host字段的%问题

    搜索: mysql数据库user表host字段的%问题 连接:http://blog.csdn.net/xiaomengh/article/details/48706149 在mysql数据库中,使用 ...

随机推荐

  1. 创建HttpFilter与理解多个Filter代码的执行顺序

    1.自定义的HttpFilter,实现Filter接口 HttpFilter package com.aff.filter; import java.io.IOException; import ja ...

  2. 【转】产生n个100以内的随机数,且不能重复

    如何高效产生m个n范围内的不重复随机数(m<=n) 给出的perl写法,以及 JAVA随机数之多种方法从给定范围内随机N个不重复数 的方法三: /** * 随机指定范围内N个不重复的数 * 在初 ...

  3. 是时候扔掉cmder, 换上Windows Terminal

    作为一个Windows的长期用户,一直没有给款好用的终端,知道遇到了 cmder,它拯救一个习惯用Windows敲shell命令的人. 不用跟我安利macOS真香!公司上班一直用macOS,一方面确实 ...

  4. Rocket - tilelink - Bundles

    https://mp.weixin.qq.com/s/jrqBg2AIpQogBrpwNXjmwg   简单介绍Bundles文件中对TileLink规范(1.7.1)的定义. 参考链接:https: ...

  5. Bom和Dom对象

    BOM-JavaScript是运行在浏览器中的,所以提供了一系列对象用于和浏览器窗口进行交互,这些对象主要包括window.document.location.navigator和screen等.通常 ...

  6. Java实现 LeetCode 332 重新安排行程

    332. 重新安排行程 给定一个机票的字符串二维数组 [from, to],子数组中的两个成员分别表示飞机出发和降落的机场地点,对该行程进行重新规划排序.所有这些机票都属于一个从JFK(肯尼迪国际机场 ...

  7. Java实现 LeetCode 146 LRU缓存机制

    146. LRU缓存机制 运用你所掌握的数据结构,设计和实现一个 LRU (最近最少使用) 缓存机制.它应该支持以下操作: 获取数据 get 和 写入数据 put . 获取数据 get(key) - ...

  8. java实现测量到的工程数据

    [12,127,85,66,27,34,15,344,156,344,29,47,-] 这是某设备测量到的工程数据. 因工程要求,需要找出最大的 5 个值. 一般的想法是对它排序,输出前 5 个.但当 ...

  9. java实现平面点最小距离

    已知平面上若干个点的坐标. 需要求出在所有的组合中,4个点间平均距离的最小值(四舍五入,保留2位小数). 比如有4个点:a,b,c,d, 则平均距离是指:ab, ac, ad, bc, bd, cd ...

  10. Java实现最小费用最大流问题

    1 问题描述 在最大流有多组解时,给每条边在附上一个单位费用的量,问在满足最大流时的最小费用是多少? 2 解决方案 下面代码所使用的测试数据如下图: package com.liuzhen.pract ...