数据库和表的基本操作

数据库基础知识

创建数据库

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. vue-cli3或者4中如何正确的使用public中的图片

    标题说的很清楚了,就是要使用public中的图片 那么为什么要把图片放到public中呢,其实官网上面也说了,要么是需要动态引入非常多的图片,特别是小图标,如果放在assert中的话,会被webpac ...

  2. Linux系统部署JavaWeb项目(超详细tomcat,nginx,mysql)

    转载自:Linux系统部署JavaWeb项目(超详细tomcat,nginx,mysql) 我的系统是阿里云的,香港的系统,本人选择的是系统镜像:CentOS 7.3 64位. 具体步骤: 配置Jav ...

  3. Android调试非常有用的命令集1_adb&aapt&git&repo&scp&while

    Linux部分场景非常有用的命令集_1_持续更新 这里面也包含了对于开发调试有用的命令,也可以看看. 这里不做详细说明或截图,仅作为记录和简单说明.注:可能只针对某一命令部分功能,不包含整个功能,若要 ...

  4. 动态生成Person类的对象 代码参考

    #include <iostream> #include <string> using namespace std; class Person { private: strin ...

  5. 远程vps管理工具巧利用,如何短时间内提高vps管理效率!

    假设你手上有1000台vps,那有没有一个免费的工具来进行有效的管理呢? 答案是有的,这里推荐一个非常好用的工具:IIS7远程桌面,免费版支持5台服务器登录,vps登录情况一目了然,高级版支持不限量台 ...

  6. jchdl - GSL值的传播

    https://mp.weixin.qq.com/s/jgMljoca-Cwe9x0NaTLzZg   GSL的拓扑模型是线和节点连接的模型,值的传播,即是值在线和节点之间传播和转化的过程.   值的 ...

  7. Java 第十一届 蓝桥杯 省模拟赛十六进制转换成十进制

    问题描述 请问十六进制数1949对应的十进制数是多少?请特别注意给定的是十六进制,求的是十进制. 答案提交 这是一道结果填空的题,你只需要算出结果后提交即可.本题的结果为一个整数,在提交答案时只填写这 ...

  8. mybatis技术总结

    一.框架概述 day1 1.什么是框架 框架是系统的可重用设计,是对J2EE底层技术的封装(JDBC,IO流,多线程,Servlet,Socket). 2.框架解决了哪些问题? 1.解决了技术整合问题 ...

  9. leetcode之两数相加解题思路

    问题描述 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但是,数组中同一个元素不能使 ...

  10. tensorflow2.0学习笔记第一章第四节

    1.4神经网络实现鸢尾花分类 import tensorflow as tf from sklearn import datasets import pandas as pd import numpy ...