mysql 总结一
mysql 总结一
数据类型(四类):
整型(5种:tinyint,smallint,mediumint, int(或integer),bigint );
浮点型:(float,double),
日期:(5种:year,time,date,datetime,timestamp),
字符:(char,varchar,tinytext,text,mediumtext,longtext,enum,set)
~~~~~~~~~~~~~~~~~~~~~~~~~我是分割线~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
show databases;
@1:打开数据库:
use 数据库名称
@2:创建表:
create table【if not exists】 table_name(
column_name data_type,
......
)
@3:查看表结构:
show COLUMNS from cost;
~~~~~~~~~~~~~~~~~~~~~~~~~我是分割线~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@1:null;not null;
@2:auto_increment;(自动编号,且必须与主键组合使用,默认起始1,增量1,可为float,但小数位必须为0);
@3:(primary )key(主键约束,每张表只有一个主键,主键自动为not null);
@4:unique key(可以为空,每张表可以由多个唯一约束)
@5:default(当插入记录时,若没有明确为字段赋值,则自动赋值默认值)
~~~~~~~~~~~~~~~~~~~~~~~~~我是分割线~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@6:外键
外键约束的要求:
#1:父表和子表必须使用相同的存储引擎(??),而且禁止使用临时表。
#2:数据表的存储引擎只能为InnoDB。
#3:外键列和参照列必须使用相似的数据类型。其中数字的长度或是否有符号位必须相同;字符的长度可以不同。
#4:外键列和参照列必须创建索引。若外键不存在索引的话,mysql将自动创建索引。
(物理)外键约束的参照操作
#1:cascade:从父表删除或更新且自动删除或更新子表中匹配的行。
#2:set null :从父表删除或更新行,并设置子表中的外键列为null。如果使用该项,必须保证子表列没有指定not null。
#3:restrict:拒绝对父表的更新或删除操作。
#4:no action:标准sql的关键字,在吗mysql中与restrict相同。
表级约束和列级约束
#1:列级约束:对一个数据列建立的约束。
#2:表级约束:对多个数据列建立的约束。
#3:列级约束可以在定义列时声明,也可以在列定以后声明。
#4:表级约束只能在列定以后声明。
~~~~~~~~~~~~~~~~~~~~~~~~~我是分割线~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@7:修改数据表
针对字段的操作: 添加/删除字段 ,修改列定义,修改列名称等;
针对约束的操作: 添加删除各种约束;
针对数据表的操作: 数据表更名(两种方式)。
添加单列
alter table table_name add [column]column_name column_definition [first|after colum_name];
添加多列
alter table table_name add [column](column_name column_definition, ...);
删除列
alter table table_name [drop [column]column_name ][,drop clomun_name];
添加主键约束
alter table table_name add [constraint [symbol]] primary key[index_type] (index_clo_name,...);
添加唯一约束
alter table table_name add [constraint [symbol]] unique[index|key] [index_name] [index_type];
(index_col_name,...);
添加外键约束
alter table table_name add [constraint [symbol]] foreign key[index_name](index_col_name,...) reference_definition;
添加/删除默认约束
alter table table_name alter [column] col_name {set default literal | drop default};
删除主键约束
alter table table_name drop primary key;
删除唯一约束
alter table table_name drop {index|key} index_name;
删除外键约束
alter table table_name drop foreign key fk_symbol;
alter table table_name drop index index_name; 删除指定列上的索引。
修改列定义
alter table table_name modify [column]col_name column_definition [first|after column_name];
修改列名称
alter table table_name change [column] old_col_name new_col_name col_definition [first|after col_name];
修改数据表名称
alter table table_name rename [to|as] new_col_name;
rename table tab_name to new_tbl_name [,tabl_name2 to new_tab_name2] ...;
~~~~~~~~~~~~~~~~~~~~~~~~~我是分割线~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
查询模板:
select select_expr[,select_expr...]
[
from table_references
[where where_condition]
[group by {col_name|prosition} [ASC|desc],...]
[having where_condition]
[order by {col_name|expr|position} [asc|desc],...]
[limit {offset, row_count|row_count OFFSET offset }]
]
mysql 总结一的更多相关文章
- Hadoop 中利用 mapreduce 读写 mysql 数据
Hadoop 中利用 mapreduce 读写 mysql 数据 有时候我们在项目中会遇到输入结果集很大,但是输出结果很小,比如一些 pv.uv 数据,然后为了实时查询的需求,或者一些 OLAP ...
- mysql每秒最多能插入多少条数据 ? 死磕性能压测
前段时间搞优化,最后瓶颈发现都在数据库单点上. 问DBA,给我的写入答案是在1W(机械硬盘)左右. 联想起前几天infoQ上一篇文章说他们最好的硬件写入速度在2W后也无法提高(SSD硬盘) 但这东西感 ...
- LINUX篇,设置MYSQL远程访问实用版
每次设置root和远程访问都容易出现问题, 总结了个通用方法, 关键在于实用 step1: # mysql -u root mysql mysql> Grant all privileges o ...
- nodejs进阶(6)—连接MySQL数据库
1. 建库连库 连接MySQL数据库需要安装支持 npm install mysql 我们需要提前安装按mysql sever端 建一个数据库mydb1 mysql> CREATE DATABA ...
- MySQL高级知识- MySQL的架构介绍
[TOC] 1.MySQL 简介 概述 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司. MySQL是一种关联数据库管理系统,将数据保存在不同的表中,而 ...
- 闰秒导致MySQL服务器的CPU sys过高
今天,有个哥们碰到一个问题,他有一个从库,只要是启动MySQL,CPU使用率就非常高,其中sys占比也比较高,具体可见下图. 注意:他的生产环境是物理机,单个CPU,4个Core. 于是,他抓取了CP ...
- 我的MYSQL学习心得(一) 简单语法
我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运 ...
- Entity Framework Core 实现MySQL 的TimeStamp/RowVersion 并发控制
将通用的序列号生成器库 从SQL Server迁移到Mysql 遇到的一个问题,就是TimeStamp/RowVersion并发控制类型在非Microsoft SQL Server数据库中的实现.SQ ...
- Docker笔记一:基于Docker容器构建并运行 nginx + php + mysql ( mariadb ) 服务环境
首先为什么要自己编写Dockerfile来构建 nginx.php.mariadb这三个镜像呢?一是希望更深入了解Dockerfile的使用,也就能初步了解docker镜像是如何被构建的:二是希望将来 ...
- 当忘记mysql数据库密码时如何进行修改
因为长时间没有使用数据库了,或者把密码改完之后就忘了数据库密码,不能正常进入数据库,也无法修改密码,有一个简单的常用修改密码方式: 1.首先找到和打开mysql.exe和mysqld.exe所在的文件 ...
随机推荐
- poj1113 凸包
result=对所有点凸包周长+pi*2*L WA了一次,被Pi的精度坑了 以后注意Pi尽可能搞精确一点.Pi=3.14还是不够用 Code: #include<vector> #incl ...
- 数据结构算法C语言实现(十四)--- 4.1&4.2串的类型定义、表示及实现
一.简述 [暂无] 二.头文件 //4_2_part1.h /** author:zhaoyu */ //2016-6-10 //----串的定长顺序存储表示---- #include "h ...
- select 1 from dual 中的1表示的含义
select 1 from dual 在这条sql语句中的1代表什么意思?查出来是个什么结果? 其实: select 1 from table; select anycol(目的表集合中的任意 ...
- Guava集合-BiMap
在本篇文章中我们将介绍Guava集合中的BiMap这个接口. com.google.common.collect Interface BiMap<K,V> BiMap接口的父接口是Map& ...
- HDU 2795 Billboard(线段树)
题目链接: 传送门 Billboard Time Limit: 2000MS Memory Limit: 32768 K Description At the entrance to the ...
- Windows系统自带工具的 cmd 命令
目标 与计算机高手无关,只是为了减少鼠标点击的次数,提高效率. 适用范围 Windows XP,Windows 7,Window 8 (在Windows 7 下验证通过.) 使用方法 在 “运行“ 对 ...
- Linux修改oracle 10g的字符集
修改数据库字符集为:ZHS16GBK查看服务器端字符集SQL > select * from V$NLS_PARAMETERS修改:$sqlplus /nologSQL>conn / as ...
- Jquery 的事件方法
1.$(selector).bind(event,data,function,map) //给元素添加一个事件 2.当元素失去焦点时发生 blur 事件,获得焦点时触发focus事件: $(" ...
- Comparable接口
java.util.Arrays类也可以对Object数组进行排序,但是要使用这种方法排序必须实现Comparable接口,此接口就是用于指定对象排序规则的. 设计一个学生类,成绩由高到低排序,成绩相 ...
- CSS学习笔记——简述
CSS3学习的教程来自后盾网 div+css网页标准布局 1>div i>DIV全称是division,意为“区块.分割”,DIV标签是一个无意义的容器标签,用于将页面划分出不同的区域 i ...