表操作
Posted 妙香沫颜
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了表操作相关的知识,希望对你有一定的参考价值。
表介绍
表相当于文件,表中的一条记录就相当于文件的一行内容,不同的是,表中的一条记录有对应的标题,称为表的字段
id,name,qq,age称为字段,其余的,一行内容称为一条记录
本节重点:
1 创建表
2 查看表结构
3 数据类型
4 表完整性约束
5 修改表
6 复制表
7 删除表
一 创建表
复制代码 语法: create table 表名( 字段名1 类型[(宽度) 约束条件], 字段名2 类型[(宽度) 约束条件], 字段名3 类型[(宽度) 约束条件] ); 注意: 1. 在同一张表中,字段名是不能相同 2. 宽度和约束条件可选 3. 字段名和类型是必须的
#1 操作文件夹(库) 增 create database db1 charset utf8; 查 show databases; show create database db1; 改 alter database db1 charset gbk; 删 drop database db1; #2 操作文件(表) 切换到文件夹下:use db1 增 create table t1(id int,name char(10))engine=innodb; create table t2(id int,name char(10))engine=innodb default charset utf8; 查 show tables; show create table t1; desc t1;#查看表结构 改 alter table t1 add age int; alter table t1 modify name char(12); 删 drop table t1; #3 操作文件的一行行内容(记录) 增 insert into db1.t1 values(1,\'egon1\'),(2,\'egon2\'),(3,\'egon3\'); insert into db1.t1(name) values(\'egon1\'),(\'egon2\'),(\'egon3\'); 查 select * from t1; select name from t1; select name,id from t1; 改 update t1 set name=\'SB\' where id=4; update t1 set name=\'SB\' where name=\'alex\'; 删 delete from t1 where id=4; #对于清空表记录有两种方式,但是推荐后者 delete from t1; truncate t1; #当数据量比较大的情况下,使用这种方式,删除速度快 #自增id create table t5(id int primary key auto_increment,name char(10)); create table t4(id int not null unique,name char(10)); insert into t5(name) values (\'egon5\'), (\'egon6\'), (\'egon7\'), (\'egon8\'), (\'egon9\'), (\'egon10\'), (\'egon11\'), (\'egon12\'), (\'egon13\'); #拷贝表结构 create table t7 select * from t5 where 1=2; alter table t7 modify id int primary key auto_increment; insert into t7(name) values (\'egon1\'), (\'egon2\'), (\'egon3\'), (\'egon4\'), (\'egon5\'), (\'egon6\'), (\'egon7\'), (\'egon8\'), (\'egon9\'), (\'egon10\'), (\'egon11\'), (\'egon12\'), (\'egon13\'); delete from t7 where id=1; #删记录 update t7 set name=\'\'; #修改字段对应的值
权限问题:创建用户,然后重新打开一个cmd,选择之前创建好的用户名和密码登录,实现功能
#创建用户 create user \'lin\'@\'localhost\' identified by \'123\';(只能在本机上,登录该用户)
create user \'lin\'@\'%\'identified by \'123\'(所有人都可以登录该用户) create user \'lin\'@\'192.168.20.%\' by \'123\'(就是说在这个局域网的计算机可以是有该用户登录)
登录时一定要输入该机器的网段
mysql -h192.168.20.97 -ulin -p123(这里的ip-) #insert,delele,update,select #级别1:对所有库,下的所有表,下的所有字段 grant select on *.* to \'lin1\'@\'localhost\' identified by \'123\'; #级别2:对db1库,下的所有表,下的所有字段 grant select on db1.* to \'lin2\'@\'localhost\' identified by \'123\'; #级别3:对表db1.t1,下的所有字段 grant select on db1.t1 to \'lin3\'@\'localhost\' identified by \'123\'; #级别4:对表db1.t1,下的id,name字段 grant select (id,name) on db1.t1 to \'lin4\'@\'localhost\' identified by \'123\'; grant select (id,name),update (name) on db1.t1 to \'lin5\'@\'localhost\' identified by \'123\'; #修改完权限后,要记得刷新权限 flush privileges;
mysql四-1:数据类型
一 介绍
存储引擎决定了表的类型,而表内存放的数据也要有不同的类型,每种数据类型都有自己的宽度,但宽度是可选的
详细参考:
- http://www.runoob.com/mysql/mysql-data-types.html
- http://dev.mysql.com/doc/refman/5.7/en/data-type-overview.html
mysql数据类型概览
二 数值类型
整数类型:TINYINT SMALLINT MEDIUMINT INT BIGINT
作用:存储年龄,等级,id,各种号码等
!!!注意:为该类型指定宽度时,仅仅只是指定查询结果的显示宽度,与存储范围无关,存储范围如下
其实我们完全没必要为整数类型指定显示宽度,使用默认的就可以了
默认的显示宽度,都是在最大值的基础上加1
int的存储宽度是4个Bytes,即32个bit,即2**32
无符号最大值为:4294967296-1
有符号最大值:2147483648-1
有符号和无符号的最大数字需要的显示宽度均为10,而针对有符号的最小值则需要11位才能显示完全,所以int类型默认的显示宽度为11是非常合理的
最后:整形类型,其实没有必要指定显示宽度,使用默认的就ok
定点数类型 DEC等同于DECIMAL
浮点类型:FLOAT DOUBLE
作用:存储薪资、身高、体重、体质参数等
======================================
decimal[(m[,d])] [unsigned] [zerofill]
准确的小数值,m是数字总个数(负号不算),d是小数点后个数。 m最大值为65,d最大值为30。
特别的:对于精确数值计算时需要用此类型
decaimal能够存储精确值的原因在于其内部按照字符串存储。
======================================
FLOAT[(M,D)] [UNSIGNED] [ZEROFILL]
单精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。
有符号:
-3.402823466E+38 to -1.175494351E-38,
0
1.175494351E-38 to 3.402823466E+38
无符号:
0
1.175494351E-38 to 3.402823466E+38
**** 数值越大,越不准确 ****
======================================
DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL]
双精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。
有符号:
-1.7976931348623157E+308 to -2.2250738585072014E-308
0
2.2250738585072014E-308 to 1.7976931348623157E+308
无符号:
0
2.2250738585072014E-308 to 1.7976931348623157E+308
**** 数值越大,越不准确 ****
MariaDB [db1]> create table t8(salary float(5,2)); #总共5位,小数部分占2位,因而整数部分最多3位
MariaDB [db1]> insert into t8 values
-> (3.3),
-> (7.33),
-> (9.335),
-> (1000.1);
MariaDB [db1]> select * from t8;
+--------+
| salary |
+--------+
| 3.30 |
| 7.33 |
| 9.34 | #4舍5入
| 999.99 | #小数最多2位,整数最多3位
+--------+
位类型:BIT
BIT(M)可以用来存放多位二进制数,M范围从1~64,如果不写默认为1位。
注意:对于位字段需要使用函数读取
bin()显示为二进制
hex()显示为十六进制
MariaDB [db1]> create table t9(id bit);
MariaDB [db1]> desc t9; #bit默认宽度为1
+-------+--------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+--------+------+-----+---------+-------+
| id | bit(1) | YES | | NULL | |
+-------+--------+------+-----+---------+-------+
MariaDB [db1]> insert into t9 values(8);
MariaDB [db1]> select * from t9; #直接查看是无法显示二进制位的
+------+
| id |
+------+
| |
+------+
MariaDB [db1]> select bin(id),hex(id) from t9; #需要转换才能看到
+---------+---------+
| bin(id) | hex(id) |
+---------+---------+
| 1 | 1 |
+---------+---------+
MariaDB [db1]> alter table t9 modify id bit(5);
MariaDB [db1]> insert into t9 values(8);
MariaDB [db1]> select bin(id),hex(id) from t9;
+---------+---------+
| bin(id) | hex(id) |
+---------+---------+
| 1 | 1 |
| 1000 | 8 |
+---------+---------+
三 日期类型
DATE TIME DATETIME TIMESTAMP YEAR
作用:存储用户注册时间,文章发布时间,员工入职时间,出生时间,过期时间等
YEAR
YYYY(1901/2155)
DATE
YYYY-MM-DD(1000-01-01/9999-12-31)
TIME
HH:MM:SS(\'-838:59:59\'/\'838:59:59\')
DATETIME
YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59 Y)
TIMESTAMP
YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)
============year===========
MariaDB [db1]> create table t10(born_year year); #无论year指定何种宽度,最后都默认是year(4)
MariaDB [db1]> insert into t10 values
-> (1900),
-> (1901),
-> (2155),
-> (2156);
MariaDB [db1]> select * from t10;
+-----------+
| born_year |
+-----------+
| 0000 |
| 1901 |
| 2155 |
| 0000 |
+-----------+
============date,time,datetime===========
MariaDB [db1]> create table t11(d date,t time,dt datetime);
MariaDB [db1]> desc t11;
+-------+----------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| d | date | YES | | NULL | |
| t | time | YES | | NULL | |
| dt | datetime | YES | | NULL | |
+-------+----------+------+-----+---------+-------+
MariaDB [db1]> insert into t11 values(now(),now(),now());
MariaDB [db1]> select * from t11;
+------------+----------+---------------------+
| d | t | dt |
+------------+----------+---------------------+
| 2017-07-25 | 16:26:54 | 2017-07-25 16:26:54 |
+------------+----------+---------------------+
============timestamp===========
MariaDB [db1]> create table t12(time timestamp);
MariaDB [db1]> insert into t12 values();
MariaDB [db1]> insert into t12 values(null);
MariaDB [db1]> select * from t12;
+---------------------+
| time |
+---------------------+
| 2017-07-25 16:29:17 |
| 2017-07-25 16:30:01 |
+---------------------+
============注意啦,注意啦,注意啦===========
1. 单独插入时间时,需要以字符串的形式,按照对应的格式插入
2. 插入年份时,尽量使用4位值
3. 插入两位年份时,<=69,以20开头,比如50, 结果2050
>=70,以19开头,比如71,结果1971
MariaDB [db1]> create table t12(y year);
MariaDB [db1]> insert into t12 values
-> (50),
-> (71);
MariaDB [db1]> select * from t12;
+------+
| y |
+------+
| 2050 |
| 1971 |
+------+
============综合练习===========
MariaDB [db1]> create table student(
-> id int,
-> name varchar(20),
-> born_year year,
-> birth date,
-> class_time time,
-> reg_time datetime);
MariaDB [db1]> insert into student values
-> (1,\'alex\',"1995","1995-11-11","11:11:11","2017-11-11 11:11:11"),
-> (2,\'egon\',"1997","1997-12-12","12:12:12","2017-12-12 12:12:12"),
-> (3,\'wsb\',"1998","1998-01-01","13:13:13","2017-01-01 13:13:13");
MariaDB [db1]> select * from student;
+------+------+-----------+------------+------------+---------------------+
| id | name | born_year | birth | class_time | reg_time |
+------+------+-----------+------------+------------+---------------------+
| 1 | alex | 1995 | 1995-11-11 | 11:11:11 | 2017-11-11 11:11:11 |
| 2 | egon | 1997 | 1997-12-12 | 12:12:12 | 2017-12-12 12:12:12 |
| 3 | wsb | 1998 | 1998-01-01 | 13:13:13 | 2017-01-01 13:13:13 |
+------+------+-----------+------------+------------+---------------------+
在实际应用的很多场景中,MySQL的这两种日期类型都能够满足我们的需要,存储精度都为秒,但在某些情况下,会展现出他们各自的优劣。下面就来总结一下两种日期类型的区别。
1.DATETIME的日期范围是1001——9999年,TIMESTAMP的时间范围是1970——2038年。
2.DATETIME存储时间与时区无关,TIMESTAMP存储时间与时区有关,显示的值也依赖于时区。在mysql服务器,操作系统以及客户端连接都有时区的设置。
3.DATETIME使用8字节的存储空间,TIMESTAMP的存储空间为4字节。因此,TIMESTAMP比DATETIME的空间利用率更高。
4.DATETIME的默认值为null;TIMESTAMP的字段默认不为空(not null),默认值为当前时间(CURRENT_TIMESTAMP),如果不做特殊处理,并且update语句中没有指定该列的更新值,则默认更新为当前时间。
四 字符串类型
#官网:https://dev.mysql.com/doc/refman/5.7/en/char.html #注意:char和varchar括号内的参数指的都是字符的长度 #char类型:定长,简单粗暴,浪费空间,存取速度快 字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节) 存储: 存储char类型的值时,会往右填充空格来满足长度 例如:指定长度为10,存>10个字符则报错,存<10个字符则用空格填充直到凑够10个字符存储 检索: 在检索或者说查询时,查出的结果会自动删除尾部的空格,除非我们打开pad_char_to_full_length SQL模式(SET sql_mode = \'PAD_CHAR_TO_FULL_LENGTH\';) #varchar类型:变长,精准,节省空间,存取速度慢 字符长度范围:0-65535(如果大于21845会提示用其他类型 。mysql行最大限制为65535字节,字符编码为utf-8:https://dev.mysql.com/doc/refman/5.7/en/column-count-limit.html) 存储: varchar类型存储数据的真实内容,不会用空格填充,如果\'ab \',尾部的空格也会被存起来 强调:varchar类型会在真实数据前加1-2Bytes的前缀,该前缀用来表示真实数据的bytes字节数(1-2Bytes最大表示65535个数字,正好符合mysql对row的最大字节限制,即已经足够使用) 如果真实的数据<255bytes则需要1Bytes的前缀(1Bytes=8bit 2**8最大表示的数字为255) 如果真实的数据>255bytes则需要2Bytes的前缀(2Bytes=16bit 2**16最大表示的数字为65535) 检索: 尾部有空格会保存下来,在检索或者说查询时,也会正常显示包含空格在内的内容
Value | CHAR(4) | Storage Required | VARCHAR(4) | Storage Required |
---|---|---|---|---|
\'\' |
\' \' |
4 bytes | \'\' |
1 byte |
\'ab\' |
\'ab \' |
4 bytes | \'ab\' |
3 bytes |
\'abcd\' |
\'abcd\' |
4 bytes | \'abcd\' |
5 bytes |
\'abcdefgh\' |
\'abcd\' |
4 bytes | \'abcd\' |
5 bytes |
测试前了解两个函数 length:查看字节数 char_length:查看字符数
1. char填充空格来满足固定长度,但是在查询时却会很不要脸地删除尾部的空格(装作自己好像没有浪费过空间一样),然后修改sql_mode让其现出原形
mysql> create table t1(x char(5),y varchar(5));
Query OK, 0 rows affected (0.26 sec)
#char存5个字符,而varchar存4个字符
mysql> insert into t1 values(\'你瞅啥 \',\'你瞅啥 \');
Query OK, 1 row affected (0.05 sec)
mysql> SET sql_mode=\'\';
Query OK, 0 rows affected, 1 warning (0.00 sec)
#在检索时char很不要脸地将自己浪费的2个字符给删掉了,装的好像自己没浪费过空间一样,而varchar很老实,存了多少,就显示多少
mysql> select x,char_length(x),y,char_length(y) from t1;
+-----------+----------------+------------+----------------+
| x | char_length(x) | y | char_length(y) |
+-----------+----------------+------------+----------------+
| 你瞅啥 | 3 | 你瞅啥 | 4 |
+-----------+----------------+------------+----------------+
1 row in set (0.00 sec)
#略施小计,让char现出原形
mysql> SET sql_mode = \'PAD_CHAR_TO_FULL_LENGTH\';
Query OK, 0 rows affected (0.00 sec)
#这下子char原形毕露了......
mysql> select x,char_length(x),y,char_length(y) from t1;
+-------------+----------------+------------+----------------+
| x | char_length(x) | y | char_length(y) |
+-------------+----------------+------------+----------------+
| 你瞅啥 | 5 | 你瞅啥 | 4 |
+-------------+----------------+------------+----------------+
1 row in set (0.00 sec)
#char类型:3个中文字符+2个空格=11Bytes
#varchar类型:3个中文字符+1个空格=10Bytes
mysql> select x,length(x),y,length(y) from t1;
+-------------+-----------+------------+-----------+
| x | length(x) | y | length(y) |
+-------------+-----------+------------+-----------+
| 你瞅啥 | 11 | 你瞅啥 | 10 |
+-------------+-----------+------------+-----------+
1 row in set (0.00 sec)
mysql> select concat(\'数据: \',x,\'长度: \',char_length(x)),concat(y,char_length(y)
) from t1;
+------------------------------------------------+--------------------------+
| concat(\'数据: \',x,\'长度: \',char_length(x)) | concat(y,char_length(y)) |
+------------------------------------------------+--------------------------+
| 数据: 你瞅啥 长度: 5 | 你瞅啥 4 |
+------------------------------------------------+--------------------------+
1 row in set (0.00 sec)
2. 虽然 CHAR 和 VARCHAR 的存储方式不太相同,但是对于两个字符串的比较,都只比 较其值,忽略 CHAR 值存在的右填充,即使将 SQL _MODE 设置为 PAD_CHAR_TO_FULL_ LENGTH 也一样,,但这不适用于like
Values in CHAR and VARCHAR columns are sorted and compared according to the character set collation assigned to the column.
All MySQL collations are of type PAD SPACE. This means that all CHAR, VARCHAR, and TEXT values are compared without regard to any trailing spaces. “Comparison” in this context does not include the LIKE pattern-matching operator, for which trailing spaces are significant. For example:
mysql> CREATE TABLE names (myname CHAR(10));
Query OK, 0 rows affected (0.03 sec)
mysql> INSERT INTO names VALUES (\'Monty\');
Query OK, 1 row affected (0.00 sec)
mysql> SELECT myname = \'Monty\', myname = \'Monty \' FROM names;
+------------------+--------------------+
| myname = \'Monty\' | myname = \'Monty \' |
+------------------+--------------------+
| 1 | 1 |
+------------------+--------------------+
1 row in set (0.00 sec)
mysql> SELECT myname LIKE \'Monty\', myname LIKE \'Monty \' FROM names;
+---------------------+-----------------------+
| myname LIKE \'Monty\' | myname LIKE \'Monty \' |
+---------------------+-----------------------+
| 1 | 0 |
+---------------------+-----------------------+
1 row in set (0.00 sec)
3. 总结
#常用字符串系列:char与varchar 注:虽然varchar使用起来较为灵活,但是从整个系统的性能角度来说,char数据类型的处理速度更快,有时甚至可以超出varchar处理速度的50%。因此,用户在设计数据库时应当综合考虑各方面的因素,以求达到最佳的平衡 #其他字符串系列(效率:char>varchar>text) TEXT系列 TINYTEXT TEXT MEDIUMTEXT LONGTEXT BLOB 系列 TINYBLOB BLOB MEDIUMBLOB LONGBLOB BINARY系列 BINARY VARBINARY text:text数据类型用于保存变长的大字符串,可以组多到65535 (2**16 − 1)个字符。 mediumtext:A TEXT column with a maximum length of 16,777,215 (2**24 − 1) characters. longtext:A TEXT column with a maximum length of 4,294,967,295 or 4GB (2**32 − 1) characters.
五 枚举类型与集合类型
字段的值只能在给定范围中选择,如单选框,多选框
enum 单选 只能在给定的范围内选一个值,如性别 sex 男male/女female
set 多选 在给定的范围内可以选择一个或一个以上的值(爱好1,爱好2,爱好3...)
create table student1( id int primary key auto_increment, name char(5), sex enum(\'male\',\'female\'), hobbies set(\'music\',\'read\',\'study\',\'coding\') ); insert into student1(name,sex,hobbies) values(\'egon\',\'None\',\'asdfasdfasdf\'); insert into student1(name,sex,hobbies) values(\'egon\',\'male\',\'music,read\');
数据实例:
1 数字(默认都是有符号,宽度指的是显示宽度,与存储无关) tinyint int bigint:个数,年龄,id,qq号,手机号 float:价格,身高,体重,余额 2 字符(宽度指的是字符个数):姓名,性别,职业,地址,职称,介绍 char:简单粗暴,不够则凑够固定长度存放起来,浪费空间,存取速度快 varchar:精准,计算出待存放的数据的长度,节省空间,存取速度慢 3 日期 #注册时间 datetime 2017-09-06 10:39:49 #出生年月日,开学时间 date:2017-09-06 #聊天记录,上课时间 time:10:39:49 #出生年 year:2017 4 枚举与集合 enum枚举:规定一个范围,可有多个值,但是为该字段传值时,只能取规定范围中的一个 set集合:规定一个范围,可有多个值,但是为该字段传值时,可以取规定范围中的一个或多个 1 : #整型测试 create table t1(id tinyint); create table t2(id int); create table t3(id bigint); #浮点型测试 0.1231233123412 3123213123123123 float:0.1231233123412 0000000000000000 double:0.1231233123412 3123213123100000 decimal: #测试 create table t4(salary float(5,2)); insert into t4 values (3.73555); insert into t4 values (-3.73555); insert into t4 values (-1111.73555); insert into t4 values (-111.73555); 2 char与varchar测试() create table t6(name char(4)); insert into t6 values(\'alexsb\'); insert into t6 values(\'欧德博爱\'); insert into t6 values(\'艾利克斯a\'); create table t7(x char(5),y varchar(5)); #insert into t7 values(\'abcdef\',\'abc\'); #insert into t7 values(\'abc\',\'abc\'); #insert into t7 values(\'abc\',\'abcdef\'); insert into t7 values(\'abc\',\'abc\'); #char_length :查看字符的长度 insert into t7 values(\'你好啊\',\'好你妹\'); #char_length :查看字符的长度 #了解 insert into t7 values(\'你好啊\',\'好你妹\'); #length:查看字节的长度 #注意两点: insert into t7 values(\'abc \',\'abc \'); #length:查看字节的长度 select * from t7 where y=\'abc \'; #去掉末尾的空格然后去比较 3:日期类型 create table student( id int, name char(5), born_date date, born_year year, reg_time datetime, class_time time ); insert into student values(1,\'alex\',now(),now(),now(),now()); insert into student values(1,\'alex\',\'2017-09-06\',\'2017\',\'2017-09-06 10:39:00\',\'08:30:00\'); #了解 insert into student values(1,\'alex\',\'2017-09-06\',2017,\'2017-09-06 10:39:00\',\'08:30:00\'); insert into student values(1,\'alex\',\'2017/09/06\',2017,\'2017-09-06 10:39:00\',\'08:30:00\'); insert into student values(1,以上是关于表操作的主要内容,如果未能解决你的问题,请参考以下文章
VSCode自定义代码片段15——git命令操作一个完整流程