Mysql之二
MySQL的数据类型
SQL接口
- 标准:
- ANSI SQL:SQL-86--------SQL-89--------SQL-99---------SQL-03
- 数据类型
- 字符型:
- CHAR(不区分字母大小写),BINARY(不区分字母大小写):定长数据类型
- VARCHARE(不区分字母大小写),VARBINARY(不区分字母大小写):变长数据类型;需要结束符
- TEXT系列(不区分字符大小写):TINYTEXT,TEXT,MEDIUMTEXT,LONGTEXT
- BLOB系列:TINYBLOB,BLOB,MEDIUMBLOB,LONGBLOB
- ENUM(枚举),SET(集合)
- 数值型
- 精确数值型:
- 整型:TINYINT,SMALLINT,MEDIUMINT,INT,BIGINT
- 十进制
- 近似数值型:
- 浮点型:FLOAT,DOUBLE
- 时间日期型
- DATE
- TIME
- DATETIME
- YEAR(2),YEAR(4)
- 内建类型
- ENUM
- SET
数据类型详解:
- 字符型:

- 字符型修饰符:
- NOT NULL:非空约束
- NULL
- DEFAUL ‘STRING’:默认值
- CHARATER SET ‘UTF8’ :使用的字符集
- COLLATION:使用的排序规则
MariaDB [(none)]> show character set; #查看支持的字符集
MariaDB [(none)]> show collation; #查看支持的字符集
- 整型数据
- 整形数据修饰符
- NOT NULL
- NULL
- AUTO_INCREDENT:
- UNSINED
- PRIMARY KEY | UNIQUE KEY
MariaDB [(none)]> select last_insert_id(); #查看最后一个插入数值的ID
+------------------+
| last_insert_id() |
+------------------+
| 0 |
+------------------+
1 row in set (0.00 sec)
- 内建类型set和人enum的修饰符
- NULL
- NOT NULL
- DEFAULT
MariaDB [tt]> create table enum_set (en ENUM('a','','1'),se SET('a','1'));
- MariaDB [tt]> insert into enum_set (en,en) values("a","a");
MariaDB [tt]> insert into enum_set (en,se) values("a","a");
- MariaDB [tt]> insert into enum_set (en,se) values("a","b");
- MariaDB [tt]> insert into enum_set (en,se) values("b","a");
- MariaDB [tt]> select * from enum_set;
+------+------+
| en | se |
+------+------+
| a | a |
| a | |
| | a |
+------+------+
3 rows in set (0.00 sec)
- SQL MODE:定义MySQL对约束等的响应行为
- 常用的SQL_MODE:TRADITIONAL,STATIC_TRANS_TABLES,STATIC_ALL_TABLES
MariaDB [tt]> show global variables like "sql_mode"; #sql_mode查询
- +---------------+--------------------------------------------+
- | Variable_name | Value |
- +---------------+--------------------------------------------+
- | sql_mode | NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION |
- +---------------+--------------------------------------------+
- 1 row in set (0.00 sec)
- MariaDB [tt]> show global variables like "sql_%"; #模糊匹配查询方式
- +------------------------+--------------------------------------------+
- | Variable_name | Value |
- +------------------------+--------------------------------------------+
- | sql_auto_is_null | OFF |
- | sql_big_selects | ON |
- | sql_buffer_result | OFF |
- | sql_log_bin | ON |
- | sql_log_off | OFF |
- | sql_mode | NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION |
- | sql_notes | ON |
- | sql_quote_show_create | ON |
- | sql_safe_updates | OFF |
- | sql_select_limit | 18446744073709551615 |
- | sql_slave_skip_counter | 0 |
- | sql_warnings | OFF |
- +------------------------+--------------------------------------------+
- 12 rows in set (0.00 sec)
MariaDB [tt]> set global sql_mode='MODE';
MariaDB [tt]> set @@global.sql_mode='MODE';
MariaDB [tt]> set session sql_mode='MODE';
MariaDB [tt]> set @@session.sql_mode='MODE';
MariaDB [mydbl]> create database ttt;
MariaDB [mydbl]> use ttt;
- MariaDB [ttt]> create table t1 (id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY NOT NULL,name CHAR(5) NOT NULL);
- MariaDB [ttt]> insert into t1 (name) values('wang'),('xuexusd'); #没修改之前会有警告,但不报错
- MariaDB [mydbl]> set sql_mode='TRADITIONAL'; #改之后,超过字符限制就会报错
- Query OK, 2 rows affected, 2 warnings (0.00 sec)
- Records: 2 Duplicates: 0 Warnings: 2
- MariaDB [ttt]> insert into t1 (name) values('wang'),('xufsdsexu');
- ERROR 1406 (22001): Data too long for column 'name' at row 1 #错误信息
SQL语言
- DDL:数据定义语言
- create alter drop
- DB组件:数据库,表,索引,视图,用户,存储过程,存储函数,触发器,事件调度器等
- create相关的常用命令
MariaDB [ttt]> help create;
- Many help items for your request exist.
- To make a more specific request, please type 'help <item>',
- where <item> is one of the following
- topics:
- CREATE DATABASE
- CREATE EVENT
- CREATE FUNCTION
- CREATE FUNCTION UDF
- CREATE INDEX
- CREATE PROCEDURE
- CREATE SERVER
- CREATE TABLE
- CREATE TABLESPACE
- CREATE TRIGGER
- CREATE USER
- CREATE VIEW
- SHOW
- SHOW CREATE DATABASE
- SHOW CREATE EVENT
- SHOW CREATE FUNCTION
- SHOW CREATE PROCEDURE
- SHOW CREATE TABLE
- SPATIAL
- DML:数据操作语言
- insert delete update select
- 数据库相关指令:
- create,alter,drop {database|schema} [if exists] [if not exists]
- 表:二维关系
- 设计表:遵循规范
- 定义:字段,索引
- 字段:字段名(不区分大小写),字段数据类型,修饰符
- 约束:索引(
- 1.应该创建在查询条件最多的字段上;
- 2.实现级别在存储引擎;
- 3.分类:
- 稠密索引;稀疏索引;
- B+索引;hash索引;R树索引;FULLTEXT索引
- 聚集索引;非聚集索引
- 创建表:
- 直接创建
CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
(create_definition,...)
[table_options]
[partition_options]
- 根据已经存在的表创建,新表会被直接插入查询而来的数据
CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
[(create_definition,...)]
[table_options]
[partition_options]
select_statement
- 根据已经存在的表结构创建,不复制数据
CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
{ LIKE old_tbl_name | (LIKE old_tbl_name) }
- 查看表
MariaDB [ttt]> desc t1; #查看表结构
+-------+------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+------------------+------+-----+---------+----------------+
| id | int(10) unsigned | NO | PRI | NULL | auto_increment |
| name | char(5) | NO | | NULL | |
+-------+------------------+------+-----+---------+----------------+
2 rows in set (0.01 sec)
MariaDB [ttt]> show tables; #查看表个数
+---------------+
| Tables_in_ttt |
+---------------+
| t1 |
+---------------+
1 row in set (0.00 sec)
- MariaDB [ttt]> show table status like 't1'\G; #查看表状态
- *************************** 1. row ***************************
- Name: t1
- Engine: InnoDB
- Version: 10
- Row_format: Compact
- Rows: 2
- Avg_row_length: 8192 #平均每行宝库奥的字节数
- Data_length: 16384 #表中数据的大小
- Max_data_length: 0
- Index_length: 0
- Data_free: 0
- Auto_increment: 3
- Create_time: 2017-01-07 13:51:08
- Update_time: NULL
- Check_time: NULL
- Collation: utf8mb4_general_ci #排序规则
- Checksum: NULL #表的校验和(性能优化)
- Create_options: #额外选项
- Comment: #注释信息
- 1 row in set (0.00 sec)
- 修改表:alter table
- 删除表:drop table
Mysql之二的更多相关文章
- MySQL优化二(连接优化和缓存优化)
body { font-family: Helvetica, arial, sans-serif; font-size: 14px; line-height: 1.6; padding-top: 10 ...
- 从零开始搭建框架SSM+Redis+Mysql(二)之MAVEN项目搭建
从零开始搭建框架SSM+Redis+Mysql(二)之MAVEN项目搭建 废话不说,直接撸步骤!!! 1.创建主项目:ncc-parent 选择maven创建项目,注意在创建项目中,packing选择 ...
- python/MySQL练习题(二)
python/MySQL练习题(二) 查询各科成绩前三名的记录:(不考虑成绩并列情况) select score.sid,score.course_id,score.num,T.first_num,T ...
- Python/MySQL(二、表操作以及连接)
Python/MySQL(二.表操作以及连接) mysql表操作: 主键:一个表只能有一个主键.主键可以由多列组成. 外键 :可以进行联合外键,操作. mysql> create table y ...
- mysql进阶(二十九)常用函数
mysql进阶(二十九)常用函数 一.数学函数 ABS(x) 返回x的绝对值 BIN(x) 返回x的二进制(OCT返回八进制,HEX返回十六进制) CEILING(x) 返回大于x的最小整数值 EXP ...
- mysql进阶(二十八)MySQL GRANT REVOKE用法
mysql进阶(二十八)MySQL GRANT REVOKE用法 MySQL的权限系统围绕着两个概念: 认证->确定用户是否允许连接数据库服务器: 授权->确定用户是否拥有足够的权限执 ...
- mysql进阶(二十七)数据库索引原理
mysql进阶(二十七)数据库索引原理 前言 本文主要是阐述MySQL索引机制,主要是说明存储引擎Innodb. 第一部分主要从数据结构及算法理论层面讨论MySQL数据库索引的数理基础. ...
- mysql进阶(二十六)MySQL 索引类型(初学者必看)
mysql进阶(二十六)MySQL 索引类型(初学者必看) 索引是快速搜索的关键.MySQL 索引的建立对于 MySQL 的高效运行是很重要的.下面介绍几种常见的 MySQL 索引类型. 在数 ...
- mysql优化二之锁机制
mysql优化二之锁机制 mysql提供了锁机制和MVCC机制来保证并发操作的安全性,这里主要讨论锁机制, MVCC见下篇文章 mysql的锁按照锁粒度可分为行锁与表锁,按照操作类型划分可读锁和写锁 ...
- MySQL基准测试(二)--方法
MySQL基准测试(二)--方法 目的: 方法不是越高级越好.而应该善于做减法.至简是一种智慧,首先要做的是收集MySQL的各状态数据.收集到了,不管各个时间段出现的问题,至少你手上有第一时间的状态数 ...
随机推荐
- 拒绝卡顿——在WPF中使用多线程更新UI
原文:拒绝卡顿--在WPF中使用多线程更新UI 有经验的程序员们都知道:不能在UI线程上进行耗时操作,那样会造成界面卡顿,如下就是一个简单的示例: public partial class MainW ...
- VS下遇到未能加载文件或程序集 错误
这个的错误原因可能是在64的系统上编译32位的应用程序,遇到这个错误,可以通过下面的手段解决! 1.关闭Visual Studio. 2. 在Visual Studio Tools子目录,以管理员身份 ...
- hadoop之eclipse环境的配置
http://hi.baidu.com/kongxianghe123/item/ea352e1040cdeffd86ad4e28
- 武汉北大青鸟解读2016年10大IT热门岗位
武汉北大青鸟解读2016年10大IT热门岗位 2016年1月5日 13:37 北大青鸟 这是IT从业者的辉煌时代,IT行业的失业率正处在历史的低点,而且有的岗位——例如网络和安全工程师以及软件开发人员 ...
- 生产环境上shell的解读
一直以来对shell都不是很熟悉,只停留在基本的linux上操作上,这周因为定位问题接触到了生产环境上的脚本,因此作为引子学习一下.很多命令只是点到,等真正需要独立完成的时候再去学习. #!/bin/ ...
- WindowsPhone8SDK重装后设计器加载异常的处理办法
Close all running instances of Visual Studio 2012 start cmd.exe (as admin/elevated) cd /d %windir%\i ...
- BZOJ2882: 工艺
题解: 裸的字符串最小表示... 可以戳这里:http://www.cnblogs.com/ACAC/archive/2010/05/23/1742349.html 这里说一下为什么a[i+k]> ...
- Java [Leetcode 40]Combination Sum II
题目描述: Given a collection of candidate numbers (C) and a target number (T), find all unique combinati ...
- RMAN数据库异机迁移
本文讲述如何用rman将一个库迁移到另一个服务器上. 服务器A:linux es4 + oracle9204 (源)服务器B:linux es4 + oracle9204 (目标) 一.创建目录 为了 ...
- HDU 5285 wyh2000 and pupil
题意:有一群人,已知某两人之间互相不认识,要把这群人分成两部分,每部分至少一人,且在每部分内没有人互不认识. 解法:图染色.某场bestcoder第二题……看完题觉得是个二分图……完全不会二分图什么的 ...