写给新手的Mysql入门指南(一)

1.数据类型

根据项目的实际需要使用合适的数据类型,这也是数据优化的操作

  • 整型
类型 存储范围 字节数
TINYINT 有符号值:-128 到 127 (-27 到 27-1)
无符号值:0 到 255 (0 到 28-1)
1
SMALLINT 有符号值:-32768 到 32767 (-215 到 215-1)
无符号值:0 到 65535 (0 到 216-1)
2
MEDIUMINT 有符号值:-8388608 到 8388607 (-223 到 223-1)
无符号值:0 到 16777215 (0 到 224-1)
3
INT 有符号值:-2147483648 到 2147483647 (-231 到 231-1)
无符号值:0 到 4294967295 (0 到 232-1)
4
BIGINT 有符号值:-9223372036854775808 到9223372036854775807 (-263 到 263-1)
无符号值:0 到 18446744073709551615 (0 到 264-1)
8
  • 浮点型
类型 存储范围 字节数
FLOAT[(M,D)] -3.402823466E+38 到 -1.175494351E-38、 0 和 1.175494351E-38 到 3.402823466E+38。
M是数字的总位数,D是小数点后面的位数。如果M和D被省略,则根据硬件允许的限制来保存值。单精度浮点数精确到大约7位小数位。
4
DOUBLE[(M,D)] -1.7976931348623157E+308 到 -2.2250738585072014E-308、 0 和 2.2250738585072014E-308 到 1.7976931348623157E+308 8
  • 字符型
类型 存储需求 用途
CHAR(M) M个字节,0 <= M <= 255 定义字符串
VARCHAR(M) L+1个字节,其中L+1 <= M 且 0 <= M <= 65535 变长字符串
TINYTEXT L+1个字节,其中L < 28 短文本字符串
TEXT L+2个字节,其中L < 216 长文本数据
MEDIUMTEXT L+3个字节,其中L < 224 二进制形式的中等长度文本数据
LONGTEXT L+4个字节,其中L < 232 极大文本数据
ENUM('value1','value2',...) 1或2个字节,取决于枚举值的个数(最多65535个值)
SET('value1','value2',...) 1、2、3、4或者8个字节,取决于set成员的数目(最多64个成员)
  • 时间类型
类型 存储范围 字节数 格式 用途
DATE 1000-01-01 / 9999-12-31 3 YYYY-MM-DD 完整的日期值
TIME '-838:59:59' / '838:59:59' 3 HH:MM:SS 时间值或持续时间
YEAR 1901 / 2155 1 YYYY 年份值
DATETIME 1000-01-01 00:00:00 / 9999-12-31 23:59:59 8 YYYY-MM-DD HH:MM:SS 混合日期和时间值
TIMESTAMP 1970-01-01 00:00:00 / 2037 年某时 8 YYYY-MM-DD HH:MM:SS 混合日期和时间值,时间戳

2.数据表的操作

关键字最好大写,这样便于阅读。可以用windows的cmd运行工具对数据库操作,前提是mysql的安装目录的子目录bin的路径添加导论系统变量PATH中,mysql -v可以查看数据库版本。登录:mysql -u用户名 -p密码,例如 mysql -uroot -p123456

  • 查看所有数据库 SHOW DATABASES;
  • 使用数据库 USE 数据库名
  • 查看当前使用的数据库 SELECT database();
  • 查看当前的用户 SELECT user();
  • 查看当前的时间 SELECT now();
  • 查看当前数据库的数据表 SHOW TABLES;
  • 查看其他数据库的数据表 SHOW TABLES FROM 数据库名;
  • 创建数据表
CREATE TABLE 数据表名(
字段 类型 设定,
字段 类型 设定
);
  • 查看数据表的结构 SHOW COLUMNS FROM 数据表名 等效命令 DESCRIBE 数据表名
  • 查看数据表中的全部数据 SELECT * FROM 数据表名

3.数据记录操作

  • 创建一个简单的数据表
CREATE TABLE t1(
    -> username VARCHAR(20) NOT NULL,
    -> age TINYINT,
    -> salary FLOAT(8,2)
    -> );
  • 查看刚才常见数据表的结构
    SHOW COLUMNS FROM t1;
Field Type Null Key Default Extra
username varchar(20) NO NULL
age tinyint(4) YES NULL
salary float(8,2) YES NULL
  • 插入一行数据
    INSERT INTO t1 VALUES('Tom',20,56310.54);
    INSERT t1(username,salary) VALUES('Jon',75654.35);

<font color="blue">INTO关键字可以省略,在表名后面不跟字段,默认数据要插入所有字段的数据,否则会报错</font>

  • 查看刚才插入数据库的所有数据
    SELECT * FROM t1;
username age salary
Tom 20 56310.54
Jon NULL 75654.35
  • 创建自增长且主键约束和唯一约束的数据表
 CREATE TABLE t2(
    -> id SMALLINT AUTO_INCREMENT PRIMARY KEY,
    -> username VARCHAR(20) NOT NULL UNIQUE,
    -> age TINYINT UNSIGNED,
    -> sex ENUM('1','2','3') DEFAULT 3
    -> );

AUTO_INCREMENT 自动编号,必须与主键 PRIMARY KEY组合使用,默认情况下,起始值为1,每次的增量为1。但是使用主键时,不一定用到自动编号

  • 查看刚才常见数据表的结构
    SELECT * FROM t2;
Field Type Null Key Default Extra
id smallint(6) NO PRI NULL auto_increment
username varchar(20) NO UNI NULL
age tinyint(3) unsigned YES NULL
sex enum('1','2','3') YES 3

唯一约束 UNIQUE 指的是该字段数据不能有重复,比如上面的数据表中就不能插入两条username都为’tom‘的数据,即使这两个人只是同名

五种约束

  • NOT NULL 非空约束
  • PRIMARY KEY 主键约束
  • UNIQUE KEY 唯一约束
  • DEFAULT 默认约束
  • NOT NULL 非空约束

外键约束

  • 1.父表和子表必须使用相同的存储引擎,而且禁止使用临时表。

  • 2.数据表的存储引擎只能为InnoDB。

  • 3.外键列和参照列必须具有相似的数据类型。其中数字的长度或是有符号位都必须相同;而字符的长度则可以不同。

  • 4.外键列和参照列必须创建索引。如果外键列不存在索引的话,MySQL将自动创建索引。

  • 创建一个省份表
 CREATE TABLE province(
    -> id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
    -> pname VARCHAR(20) NOT NULL
    -> );
  • 查看创建表时的命令

SHOW CREATE TABLE province\G;
后面加上\G,可以过滤不必要的信息,方便查看。

            Table: province
Create Table: CREATE TABLE `province` (
  `id` smallint(5) unsigned NOT NULL AUTO_INCREMENT,
  `pname` varchar(20) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

可以看出符合存储引擎为InnoDB的外键约束要求

  • 创建一个子表用户表
CREATE TABLE user(
    -> id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
    -> username VARCHAR(10) NOT NULL,
    -> pid SMALLINT UNSIGNED,
    -> FOREIGN KEY (pid) REFERENCES province (id)
    -> );

pid 作为外键列,province作为父表,其id为参照列,如果pid的数据类型和参照列的数据类型不同或者符号位不同,那么会报出150错误,创建子表失败。

  • 查看数据表的索引

SHOW INDEX FROM province\G;

*************************** 1. row ***************************
        Table: province
   Non_unique: 0
     Key_name: PRIMARY
 Seq_in_index: 1
  Column_name: id
    Collation: A
  Cardinality: 0
     Sub_part: NULL
       Packed: NULL
         Null:
   Index_type: BTREE
      Comment:
Index_comment:

SHOW INDEX FROM user\G;

*************************** 1. row ***************************
        Table: user
   Non_unique: 0
     Key_name: PRIMARY
 Seq_in_index: 1
  Column_name: id
    Collation: A
  Cardinality: 0
     Sub_part: NULL
       Packed: NULL
         Null:
   Index_type: BTREE
      Comment:
Index_comment:
*************************** 2. row ***************************
        Table: user
   Non_unique: 1
     Key_name: pid
 Seq_in_index: 1
  Column_name: pid
    Collation: A
  Cardinality: 0
     Sub_part: NULL
       Packed: NULL
         Null: YES
   Index_type: BTREE
      Comment:
Index_comment:
  • 查看user的数据表创建命令

SHOW CREATE TABLE user\G;

*************************** 1. row ***************************
       Table: user
Create Table: CREATE TABLE `user` (
  `id` smallint(5) unsigned NOT NULL AUTO_INCREMENT,
  `username` varchar(10) NOT NULL,
  `pid` smallint(5) unsigned DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `pid` (`pid`),
  CONSTRAINT `user_ibfk_1` FOREIGN KEY (`pid`) REFERENCES `province` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

通过查看user表的创建命令,可以发现系统自动为子表的pid创建了索引id,参考(reference)province表的id。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,126评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,254评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,445评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,185评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,178评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,970评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,276评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,927评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,400评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,883评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,997评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,646评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,213评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,204评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,423评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,423评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,722评论 2 345

推荐阅读更多精彩内容

  • 1、MySQL启动和关闭(安装及配置请参照百度经验,这里不再记录。MySQL默认端口号:3306;默认数据类型格式...
    强壮de西兰花阅读 634评论 0 1
  • 什么是SQL数据库: SQL是Structured Query Language(结构化查询语言)的缩写。SQL是...
    西贝巴巴阅读 1,801评论 0 10
  • 图片发自简书App 每个人都曾爱过一个人,也许成了爱人,也许成了过往 我认识满哥的时候是在盼盼的生日聚会上,他是盼...
    Gardenia栀子阅读 592评论 1 0
  • 这是一篇无标题的文章,因为还没想好写什么。 之前有过一个账号,写过几句话,这次换了微信登录,只是希望能更方便一点。...
    大虾_小喵阅读 199评论 0 0
  • 寒日吟 衙斋森森尺椟冷,寒月拢霜布衾凉。 半窗尘辉山河远,一思惆怅诉离殇。 ​​​
    园_48c5阅读 170评论 0 0