MySQL系列:数据表基本操作(2)
1. 指定数据库
mysql> use portal;
2. 数据库表基本操作
2.1 查看数据表
mysql> show tables;
+------------------+
| Tables_in_portal |
+------------------+
| product |
+------------------+
3. 创建表
3.1 创建表语法
CREATE TABLE table_name (column_name column_type);
mysql> CREATE TABLE product
-> (
-> product_id INT,
-> product_name VARCHAR(50)
-> );
3.2 设置主键
单字段主键:
column_name column_type PRIMARY KEY
mysql> CREATE TABLE product
-> (
-> product_id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
-> product_name VARCHAR(50)
-> );
多字段主键:
PRIMARY KEY (column_name, ... , column_name)
mysql> CREATE TABLE product
-> (
-> product_id INT,
-> category_id INT,
-> product_name VARCHAR(50),
-> PRIMARY KEY (product_id, category_id)
-> );
3.3 设置外键
CONSTRAINT constraint_name FOREIGN KEY(column_name, ... , column_name) REFERENCES table_name(column_name, ... ,column_name)
mysql> CREATE TABLE category
-> (
-> category_id INT PRIMARY KEY,
-> category_name VARCHAR(50)
-> );
mysql> CREATE TABLE product
-> (
-> product_id INT PRIMARY KEY,
-> product_name VARCHAR(50),
-> category_id INT,
-> CONSTRAINT FK_product_category FOREIGN KEY(category_id) REFERENCES category(category_id)
-> );
3.4 设置非空约束
column_name column_type NOT NULL
mysql> CREATE TABLE product
-> (
-> product_id INT PRIMARY KEY,
-> product_name VARCHAR(50) NOT NULL
-> );
3.5 设置唯一约束
column_name column_type unique
mysql> CREATE TABLE product
-> (
-> product_id INT PRIMARY KEY,
-> product_name VARCHAR(50) UNIQUE
-> );
3.6 设置字段值自动增加
column_name column_type AUTO_INCREMENT
mysql> CREATE TABLE product
-> (
-> product_id INT AUTO_INCREMENT PRIMARY KEY,
-> product_name VARCHAR(50)
-> );
MySQL规定自增长列必须为主键。
AUTO_INCREMENT默认从1开始,每次加1。
创建表时指定AUTO_INCREMENT自增值的初始值(即起始值):
mysql> CREATE TABLE product
-> (
-> product_id INT AUTO_INCREMENT PRIMARY KEY,
-> product_name VARCHAR(50)
-> ) AUTO_INCREMENT = 100;
通过 ALTER TABLE 修改初始值(但是要大于表中的 AUTO_INCREMENT 自增值,否则设置无效):
mysql> ALTER TABLE product AUTO_INCREMENT = 100;
查询指定表的AUTO_INCREMENT值:
mysql> SELECT AUTO_INCREMENT FROM information_schema.TABLES WHERE table_name = "product";
查看AUTO_INCREMENT相关的变量设置:
mysql> SHOW VARIABLES LIKE 'auto_increment%';
+--------------------------+-------+
| Variable_name | Value |
+--------------------------+-------+
| auto_increment_increment | 1 |
| auto_increment_offset | 1 |
+--------------------------+-------+
其中,auto_increment_increment:自增量每次增加的值,
auto_increment_offset:加载数值时的偏移值的个位值。
修改设置auto_increment_increment:
mysql> SET @@auto_increment_increment = 10;
mysql> SHOW VARIABLES LIKE 'auto_increment%';
+--------------------------+-------+
| Variable_name | Value |
+--------------------------+-------+
| auto_increment_increment | 10 |
| auto_increment_offset | 1 |
+--------------------------+-------+
mysql> INSERT INTO product(product_name) VALUES ('商品01'),('商品02'),('商品03'),('商品04'),('商品05');
mysql> SELECT product_id,product_name FROM product;
+------------+--------------+
| product_id | product_name |
+------------+--------------+
| 1 | 商品01 |
| 11 | 商品02 |
| 21 | 商品03 |
| 31 | 商品04 |
| 41 | 商品05 |
+------------+--------------+
修改设置auto_increment_increment及auto_increment_offset:
mysql> SET @@auto_increment_increment = 10;
mysql> SET @@auto_increment_offset = 5;
mysql> SHOW VARIABLES LIKE 'auto_increment%';
+--------------------------+-------+
| Variable_name | Value |
+--------------------------+-------+
| auto_increment_increment | 10 |
| auto_increment_offset | 5 |
+--------------------------+-------+
mysql> INSERT INTO product(product_name) VALUES ('商品01'),('商品02'),('商品03'),('商品04'),('商品05');
mysql> SELECT product_id,product_name FROM product;
+------------+--------------+
| product_id | product_name |
+------------+--------------+
| 5 | 商品01 |
| 15 | 商品02 |
| 25 | 商品03 |
| 35 | 商品04 |
| 45 | 商品05 |
+------------+--------------+
当auto_increment_offset设置的值大于auto_increment_increment值时,auto_increment_offset设置无效。
3.7 设置字段默认值
column_name column_type DEFAULT default_value
mysql> CREATE TABLE product
-> (
-> product_id INT PRIMARY KEY AUTO_INCREMENT,
-> product_name VARCHAR(50),
-> unit_price FLOAT DEFAULT 0
-> );
4. 查看表
4.1 查看表基本结构语句 DESC
DESC table_name
mysql> DESC product;
+-------------+-------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------------+-------------+------+-----+---------+----------------+
| product_id | int(11) | NO | PRI | NULL | auto_increment |
| product_name | varchar(50) | YES | | NULL | |
| unit_price | float | YES | | 0 | |
+-------------+-------------+------+-----+---------+----------------+
3 rows in set (0.02 sec)
4.2 查看表详细结构语句SHOW CREATE TABLE
SHOW CREATE TABLE table_name;
mysql> SHOW CREATE TABLE product;
5. 修改表
5.1 修改表名
ALTER TABLE old_table_name RENAME [TO] new_table_name;
mysql> ALTER TABLE product RENAME product1;
5.2 修改字段数据类型
ALTER TABLE table_name MODIFY column_name column_type FIRST | AFTER column_name
mysql> ALTER TABLE product MODIFY product_name VARCHAR(100);
mysql> ALTER TABLE product MODIFY product_name VARCHAR(100) NOT NULL;
mysql> ALTER TABLE product MODIFY product_name VARCHAR(100) FIRST;
mysql> ALTER TABLE product MODIFY product_name VARCHAR(100) AFTER id;
5.3 修改字段名
ALTER TABLE table_name CHANGE old_column_name new_column_name new_column_type
mysql> ALTER TABLE product CHANGE product_name Name VARCHAR(50);
5.4 增加字段
ALTER TABLE table_name ADD column_name column_type [CONSTRAINT] [FIRST | AFTER column_name];
mysql> ALTER TABLE product ADD unit_price FLOAT NOT NULL;
mysql> ALTER TABLE product ADD ID INT NOT NULL FIRST;
mysql> ALTER TABLE product ADD product_no VARCHAR(50) NOT NULL AFTER product_id;
5.5 删除字段
ALTER TABLE table_name DROP column_name;
mysql> ALTER TABLE product DROP ID;
5.6 修改字段排列位置
ALTER TABLE table_name MODIFY column_name column_type FIRST | AFTER colunm_name;
mysql> ALTER TABLE product MODIFY product_no VARCHAR(50) FIRST;
mysql> ALTER TABLE product MODIFY product_no VARCHAR(50) AFTER product_id;
5.7 修改表存储引擎
ALTER TABLE table_name ENGINE=engine_name;
mysql> ALTER TABLE product ENGINE = MyISAM;
mysql> SHOW CREATE TABLE product\G;
5.8 删除表的外键约束
ALTER TABLE table_name DROP FOREIGN KEY constraint_name;
mysql> CREATE TABLE category
-> (
-> id INT UNSIGNED NOT NULL AUTO_INCREMENT,
-> category_name VARCHAR(100) NOT NULL,
-> PRIMARY KEY(id)
-> );
mysql> CREATE TABLE product
-> (
-> id INT UNSIGNED NOT NULL AUTO_INCREMENT,
-> category_id INT UNSIGNED NOT NULL,
-> product_name VARCHAR(100) NOT NULL,
-> PRIMARY KEY(id),
-> CONSTRAINT fk_product_category FOREIGN KEY (category_id) REFERENCES category(id)
-> );
mysql> ALTER TABLE product DROP FOREIGN KEY fk_product_category;
6. 删除表
DROP TABLE [IF EXISTS] table_name, table_name, table_name, ...;
mysql> DROP TABLE product;
MySQL系列:数据表基本操作(2)的更多相关文章
- MySQL:数据表基本操作
数据表基本操作 注意点: 1.数据表中已经有数据时,轻易修改数据类型,有可能因为不同的数据类型的数据在机器 中存储的方式及长度并不相同,修改数据类型可能会影响到数据表中已有的数据类型. 2. 数据表 ...
- mysql学习——数据表基本操作1
选择数据库 创建数据表 包括字段名和数据类型两部分 查看数据表 使用主键约束 主键又称主码,能够唯一的表示表中的一条记录,分为单字段主键与多字段联合主键 单字段主键 定义主键的两种方式: 1.在最后指 ...
- mysql(三) 数据表的基本操作操作
mysql(三) 数据表的基本操作操作 创建表,曾删改查,主键,外键,基本数据类型. 1. 创建表 create table 表名( 列名 类型 是否可以为空, 列名 类型 是否可以为空 )ENGIN ...
- MySQL为数据表的指定字段插入数据
username not null 没有默认值/有默认值 insert不插入username字段 均不报错 2014年07月23日21:05 百科369 MySQL为数据表的指定字段插入数据 ...
- MySQL 删除数据表
MySQL 删除数据表 MySQL中删除数据表是非常容易操作的, 但是你再进行删除表操作时要非常小心,因为执行删除命令后所有数据都会消失. 语法 以下为删除MySQL数据表的通用语法: DROP TA ...
- MySQL 创建数据表
MySQL 创建数据表 创建MySQL数据表需要以下信息: 表名 表字段名 定义每个表字段 语法 以下为创建MySQL数据表的SQL通用语法: CREATE TABLE table_name (col ...
- MySQL查询数据表中数据记录(包括多表查询)
MySQL查询数据表中数据记录(包括多表查询) 在MySQL中创建数据库的目的是为了使用其中的数据. 使用select查询语句可以从数据库中把数据查询出来. select语句的语法格式如下: sele ...
- MySQL修改数据表存储引擎的3种方法介绍
这篇文章主要介绍了MySQL修改数据表存储引擎的3种方法介绍,分别是直接修改.导出导入.创建插入3种方法, 可以参考下 MySQL作为最常用的数据库,经常遇到各种各样的问题.今天要说的就是表存储引 ...
- MySQL对数据表进行分组查询
MySQL对数据表进行分组查询(GROUP BY) GROUP BY关键字可以将查询结果按照某个字段或多个字段进行分组.字段中值相等的为一组.基本的语法格式如下: GROUP BY 属性名 [HAVI ...
- MySQL对数据表进行分组查询(GROUP BY)
MySQL对数据表进行分组查询(GROUP BY) GROUP BY关键字可以将查询结果按照某个字段或多个字段进行分组.字段中值相等的为一组.基本的语法格式如下: GROUP BY 属性名 [HAVI ...
随机推荐
- Linux进程管理 (9)实时调度类分析,以及FIFO和RR对比实验
关键词:rt_sched_class.SCHED_FIFO.SCHED_RR.sched_setscheduler().sched_setaffinity().RR_TIMESLICE. 本文主要关注 ...
- 我的微软最有价值专家(Microsoft MVP)之路
一.写在前面 2018年对我来说是幸运的一年,对我来说最幸运的事情有两个,一个是在离驾照考试过期还有一个月(报名之后一直没去考)终于拿到了我的驾照,还有一件事莫过于获得了微软MVP.期间,一直有朋友问 ...
- A2D JS框架 - AOP封装
AOP在js中的实现,先看看用法吧: var A2D = $.noConflict();//不要误会,此乃我自己写的A2D框架,非jQuery function fn1(name, age) { co ...
- [LeetCode] 56 - Merge Intervals 合并区间
Given a collection of intervals, merge all overlapping intervals. For example,Given [1,3],[2,6],[8,1 ...
- HDU - 1698 线段树区间修改,区间查询
这就是很简单的基本的线段树的基本操作,区间修改,区间查询,对区间内部信息打上laze标记,然后维护即可. 我自己做的时候太傻逼了...把区间修改写错了,对给定区间进行修改的时候,mid取的是节点的左右 ...
- Python入门-格式化输出
需求:将用户的姓名.年龄.工作.爱好 ,然后打印成以下格式: ------------ Info of Tom ------ Name : Tom Age : 22 Job : Teacher Hob ...
- from bs4 import BeautifulSoup 报错
一: BeautifulSoup的安装: 下载地址:https://www.crummy.com/software/BeautifulSoup/bs4/download/4.6/ 下载后,解压缩,然后 ...
- 第十二届湖南省赛 A - 2016 ( 数学,同余转换)
给出正整数 n 和 m,统计满足以下条件的正整数对 (a,b) 的数量: 1. 1≤a≤n,1≤b≤m; 2. a×b 是 2016 的倍数. Input 输入包含不超过 30 ...
- pandas数据清洗策略2
首先,我们先要读入数据: 然后检查数据出现的问题: 1.没有表头,增加表头 2.去除重复值: df.duplicate()使用布尔数据查看数据表中是否有重复值,df.drop_duplicates() ...
- PS调出唯美冷色情侣婚纱写真照
一.打开PS原片,原片是一张JPG格式的片子 色温较高整个画面较红离对着上面的我们标准的韩式色调我们来进行调节吧 ,我就不打太多文字解释一些基本常规了 二.韩式婚纱内景喜欢加点烟雾.其实我本人是不太喜 ...