MySQL操作表和表记录 mysql 操作数据记录
lipiwang 2024-10-22 15:47 5 浏览 0 评论
操作表
增
创建表语法
创建一个表,多个字段:
create table 表名(
字段名 列类型 [可选的参数], # 记住要加逗号
字段名 列类型 [可选的参数] # 最后一行不加逗号
...
)charset=utf8; # 后面加;号
列约束
说明:列约束用来保证数据的完整性和一致性,约束条件都是创建表语法的时候可选参数
- auto_increment:表示自增加1
- not null:标识该字段不能为空
- ``default:为该字段设置默认值`
- foreign key:外键索引
- unique key:标识字段的值是唯一的,字段值不能重复,可以有多个
- primary key:主键索引,可以加快查询速度,字段值不能重复,只能有一个
- unsigned:无符号,默认是有符号的
- zerofill:使用0填充
例子
# 创建表
mysql> create table t3(
-> id int unsigned auto_increment primary key,
-> name char(10) not null default "xxx",
-> age int not null default 0
-> )charset=utf8;
Query OK, 0 rows affected (0.03 sec)
# 向表中插入数据
mysql> insert into t3 (age) values (18);
Query OK, 1 row affected (0.00 sec)
# 查询表中数据
mysql> select * from t3;
+----+------+-----+
| id | name | age |
+----+------+-----+
| 1 | xxx | 18 |
+----+------+-----+
1 row in set (0.00 sec)
# 查看表结构 desc 表名
mysql> desc t3;
+-------+------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+------------------+------+-----+---------+----------------+
| id | int(10) unsigned | NO | PRI | NULL | auto_increment |
| name | char(10) | NO | | xxx | |
| age | int(11) | NO | | 0 | |
+-------+------------------+------+-----+---------+----------------+
3 rows in set (0.00 sec)
列类型
列类型 | 说明 |
数字(整数) | 存储年龄、等级、id等 |
数字(浮点数) | 存储薪资、身高、体重等 |
字符串 | 存储姓名、性别等 |
时间日期类型 | 存储注册时间、入职时间等 |
枚举 | 字段的值只能在给定范围中选择 |
数字(整形)
- tinyint:小整数,有符号:[-128 ~ 127],无符号:[0 ~ 255]
- smallint:大整数,有符号:[-32768 ~ 32767],无符号:[0 ~ 65535]
- mediumint:大整数
- bigint:极大整数
- int (推荐使用):大整数,有符号:[-2147483648 ~ 2147483647],无符号:[0 ~ 4294967295]
unsigned 加在列类型后面,代表无符号,不能取负数,默认是有符号,可以是负数
应用场景:根据公司业务场景选择合适类型
例子:
# 我们创建一个t4表,限制使用无符号的
mysql> create table t4(x int unsigned);
Query OK, 0 rows affected (0.02 sec)
# 查看表结构,默认int数值长度已经设置为10位
mysql> desc t4;
+-------+------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+------------------+------+-----+---------+-------+
| x | int(10) unsigned | YES | | NULL | |
+-------+------------------+------+-----+---------+-------+
1 row in set (0.00 sec)
# 只能插入无符号:[0 ~ 4294967295]范围值内的数字
# 超过数字的长度也报错
mysql> insert into t4 values (42949672955);
ERROR 1264 (22003): Out of range value for column 'x' at row 1
# 只能插入无符号:[0 ~ 4294967295]范围值内的数字
# 超过范围即报错
mysql> insert into t4 values (4294967296);
ERROR 1264 (22003): Out of range value for column 'x' at row 1
# 在这个范围内则成功
mysql> insert into t4 values (4294967295);
Query OK, 1 row affected (0.00 sec)
# 查询插进去的数据,如果数据库配置是非安全模式的话,插进去的数据是这个数据类型限制的最大数值
mysql> select * from t4;
+------------+
| x |
+------------+
| 4294967295 |
| 4294967295 |
+------------+
2 rows in set (0.00 sec)
注意:那么有的同学可能不会报错,能插进去,那是因为你的mysql5.6 没有开启安全模式,mysql5.7 以后的版本默认都是安全模式
# 查看当前数据库模式:
mysql> show variables like "%sql_mode%";
+---------------+--------------------------------------------+
| Variable_name | Value |
+---------------+--------------------------------------------+
| sql_mode | STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION |
+---------------+--------------------------------------------+
1 row in set (0.00 sec)
sql_model=no_engine_substitution # 非安全性,默认
sql_model=strict_trans_tables # 安全性
# 临时设置为安全模式,服务重启后会被重置
mysql>: set global sql_mode="strict_trans_tables"; # 在root用户登录状态下
# 在设置后,quit断开数据库连接后(服务器不重启)就会进入安全模式,
# 那么现在在插入超过范围内的数据就会报错
数字(浮点型)
- float:不一定精确
- decimal(m,d):存精确的数字,m是数字总个数(负号不算),d是小数点后的数字个数
例子:
# 创建表t5 限制salary字段为decimal数据类型,num为float数据类型
mysql> create table t5(
-> id int auto_increment primary key,
-> salary decimal(16,10),
-> num float
-> )charset=utf8;
Query OK, 0 rows affected (0.02 sec)
# 查看表结构
mysql> desc t5;
+--------+----------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+--------+----------------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| salary | decimal(16,10) | YES | | NULL | |
| num | float | YES | | NULL | |
+--------+----------------+------+-----+---------+----------------+
3 rows in set (0.00 sec)
# 插入数据,salary总数字长度为16,小数点后面正好为10位,插入数据
mysql> insert into t5 (salary,num) values (500000.2312345678,5000.232423523534634);
Query OK, 1 row affected (0.01 sec)
# 查询没有问题,精确存,但是num float类型的不精确,存两位小数点,还四舍五入了
mysql> select * from t5;
+----+-------------------+---------+
| id | salary | num |
+----+-------------------+---------+
| 1 | 500000.2312345678 | 5000.23 |
+----+-------------------+---------+
1 row in set (0.00 sec)
# 插入数据,salary总数字长度为15,小数点后面小于10位,插入数据mysql> insert into t5 (salary,num) values (500000.231234567,5000.232423523534634);
Query OK, 1 row affected (0.01 sec)
# 查询,不精确,缺省的一位用0补齐,但是num float类型的不精确,存两位小数点,还四舍五入了
mysql> select * from t5;
+----+-------------------+---------+
| id | salary | num |
+----+-------------------+---------+
| 1 | 500000.2312345678 | 5000.23 |
| 2 | 500000.2312345670 | 5000.23 |
+----+-------------------+---------+
2 rows in set (0.00 sec)
# 插入数据,salary总数字长度为17,小数点后面大于10位,插入数据
mysql> insert into t5 (salary,num) values (500000.23123456789,5000.232423523534634);
Query OK, 1 row affected, 1 warning (0.01 sec)
# 查询,不精确,只能存指定的长度,多出来的四舍五入了,但是num float类型的不精确,存两位小数点,还四舍五入了
mysql> select * from t5;
+----+-------------------+---------+
| id | salary | num |
+----+-------------------+---------+
| 1 | 500000.2312345678 | 5000.23 |
| 2 | 500000.2312345670 | 5000.23 |
| 3 | 500000.2312345679 | 5000.23 |
+----+-------------------+---------+
3 rows in set (0.00 sec)
字符串
- char:定长
- varchar:变长
两者区别:
char 定长,无论插入字符是多少个,永远固定占规定的长度,使用场景:身份证、手机号、md5加密过后的密码char(32)
varchar 变长,根据插入的字符串长度计算所占的字节数,但是总有一个字节是用来保存字符串大小的,
如果不能确定插入的数据的大小,一般建议使用varchar(255)。
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 |
例子:
# 创建t6表
mysql> create table t6(
-> id int unsigned auto_increment primary key,
-> name char(10) not null default 'xxx'
-> )charset=utf8;
Query OK, 0 rows affected (0.02 sec)
mysql> desc t6;
+-------+------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+------------------+------+-----+---------+----------------+
| id | int(10) unsigned | NO | PRI | NULL | auto_increment |
| name | char(10) | NO | | xxx | |
+-------+------------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)
# 创建t7表
mysql> create table t7(
-> id int unsigned auto_increment primary key,
-> name varchar(10) not null default 'xxx'
-> )charset=utf8;
Query OK, 0 rows affected (0.03 sec)
mysql> desc t7;
+-------+------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+------------------+------+-----+---------+----------------+
| id | int(10) unsigned | NO | PRI | NULL | auto_increment |
| name | varchar(10) | NO | | xxx | |
+-------+------------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)
mysql> insert into t6 (name) values ("hello");
Query OK, 1 row affected (0.01 sec)
mysql> insert into t7 (name) values ("hello");
Query OK, 1 row affected (0.01 sec)
mysql> select * from t6;
+----+-------+
| id | name |
+----+-------+
| 1 | hello |
+----+-------+
1 row in set (0.00 sec)
mysql> select * from t7;
+----+-------+
| id | name |
+----+-------+
| 1 | hello |
+----+-------+
1 row in set (0.00 sec)
mysql> insert into t6 (name) values ("hello32dwdsaffgfrthtrhtr");
ERROR 1406 (22001): Data too long for column 'name' at row 1
mysql> insert into t7 (name) values ("hello32dwdsaffgfrthtrhtr");
ERROR 1406 (22001): Data too long for column 'name' at row 1
时间日期类型
- year:保存年份
- date:保存日期
- time:保存时间
- datetime:保存格式化后的时间
- timestamp:保存时间戳
例子:
mysql> create table t8(
-> d date,
-> t time,
-> dt datetime
-> );
Query OK, 0 rows affected (0.04 sec)
mysql> desc t8;
+-------+----------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| d | date | YES | | NULL | |
| t | time | YES | | NULL | |
| dt | datetime | YES | | NULL | |
+-------+----------+------+-----+---------+-------+
3 rows in set (0.00 sec)
# now()表示当前时间
mysql> insert into t8 values(now(),now(),now());
Query OK, 1 row affected, 1 warning (0.00 sec)
# 按照指定时间类型存时间
mysql> select * from t8;
+------------+----------+---------------------+
| d | t | dt |
+------------+----------+---------------------+
| 2019-10-29 | 01:23:08 | 2019-10-29 01:23:08 |
+------------+----------+---------------------+
1 row in set (0.00 sec)
枚举
列出所有选项
mysql> create table t9(
-> id int auto_increment primary key,
-> gender enum("male","female")
-> )charset=utf8;
Query OK, 0 rows affected (0.03 sec)
mysql> insert into t9 (gender) values ("male");
Query OK, 1 row affected (0.00 sec)
mysql> insert into t9 (gender) values ("female");
Query OK, 1 row affected (0.00 sec)
# 只能插入枚举类型的数据
mysql> insert into t9 (gender) values ("femal");
ERROR 1265 (01000): Data truncated for column 'gender' at row 1
mysql>
mysql> select * from t9;
+----+--------+
| id | gender |
+----+--------+
| 1 | male |
| 2 | female |
+----+--------+
2 rows in set (0.00 sec)
删
drop table 表名
改
修改表名
语法:
alter table 旧表名 rename 新表名
增加字段
语法:
alter table 表名 add 字段名 列类型 [可选的参数];
上面添加的列永远是添加在最后一列之后,如果需要在指定位置添加字段的话,使用下面的语法
alter table 表名 add 字段名 列类型 [可选的参数] first;
alter table 表名 add 字段名 列类型 [可选的参数] after 字段名
修改字段
alter table 表名 modify 字段名 列类型 [可选的参数]
alter table 表名 change 旧字段名 新字段名 系列类型 [可选的参数]
删除字段
alter table 表名 drop 字段名
查
show tables:查看表名
复制表结构
1、 查看被复制表的创建语句:show create table 表名,然后拷贝sql语句更换表名执行
2、 create table 旧表名 like 新表名
操作表数据
增
增加数据,语法:
insert into 表名 (列1,列2) values (值1,值2)
删
delete from 表名 where 条件 ;如果不加条件删除表中所有数据
truncate 表名;没有where条件,删除表中全部数据,速度比delete快
两者区别:
1、 delete删除之后再插入数据,自增id从上一次主键自增,truncate是从1开始
2、 delete删除是一行一行删除,truncate是全选删除,速度比delete快
改
update 表名 set 列名1=新值1 where 条件
查
语法:
select 列1,列2 from 表名 [where 条件]
select * from 表名 where id between ... and ...;between...and...取值范围是闭区间
查询去重
select distinct 列名 from 表名
四则运算
select 列表*10 from 表名
in
select * from 表名 where id in (取值范围)
like模糊查询
select * from 表名 where 列名 like 'x%'; 以x开头,%表示通配符
select * from 表名 where 列名 like '%x'; 以x结尾,%表示通配符
select * from 表名 where 列名 like '%x%' 包含x的,%表示通配符
相关推荐
- ubuntu单机安装open-falcon极度详细操作
-
备注:以下操作均由本人实际操作并得到验证,喜欢的同学可尝试操作安装。步骤一1.1环境准备(使用系统:ubuntu18.04)1.1.1安装redisubuntu下安装(参考借鉴:https://...
- Linux搭建promtail、loki、grafana轻量日志监控系统
-
一:简介日志监控告警系统,较为主流的是ELK(Elasticsearch、Logstash和Kibana核心套件构成),虽然优点是功能丰富,允许复杂的操作。但是,这些方案往往规模复杂,资源占用高,...
- 一文搞懂,WAF阻止恶意攻击的8种方法
-
WAF(Web应用程序防火墙)是应用程序和互联网流量之间的第一道防线,它监视和过滤Internet流量以阻止不良流量和恶意请求,WAF是确保Web服务的可用性和完整性的重要安全解决方案。它...
- 14配置appvolume(ios14.6配置文件)
-
使用AppVolumes应用程序功能,您可以管理应用程序的整个生命周期,包括打包、更新和停用应用程序。您还可以自定义应用程序分配,以向最终用户提供应用程序的特定版本14.1安装appvolume...
- 目前流行的缺陷管理工具(缺陷管理方式存在的优缺点)
-
摘自:https://blog.csdn.net/jasonteststudy/article/details/7090127?utm_medium=distribute.pc_relevant.no...
- 开源数字货币交易所开发学习笔记(2)——SpringCloud
-
前言码云(Gitee)上开源数字货币交易所源码CoinExchange的整体架构用了SpringCloud,对于经验丰富的Java程序员来说,可能很简单,但是对于我这种入门级程序员,还是有学习的必要的...
- 开发JAX-RPC Web Services for WebSphere(下)
-
在开发JAX-RPCWebServicesforWebSphere(上)一文中,小编为大家介绍了如何创建一个Web服务项目、如何创建一个服务类和Web服务,以及部署项目等内容。接下来小编将为大...
- CXF学习笔记1(cxf client)
-
webservice是发布服务的简单并实用的一种技术了,个人学习了CXF这个框架,也比较简单,发布了一些笔记,希望对笔友收藏并有些作用哦1.什么是webServicewebService让一个程序可...
- 分布式RPC最全详解(图文全面总结)
-
分布式通信RPC是非常重要的分布式系统组件,大厂经常考察的Dubbo等RPC框架,下面我就全面来详解分布式通信RPC@mikechen本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集》...
- Oracle WebLogic远程命令执行0day漏洞(CVE-2019-2725补丁绕过)预警
-
概述近日,奇安信天眼与安服团队通过数据监控发现,野外出现OracleWebLogic远程命令执行漏洞最新利用代码,此攻击利用绕过了厂商今年4月底所发布的最新安全补丁(CVE-2019-2725)。由...
- Spring IoC Container 原理解析(spring中ioc三种实现原理)
-
IoC、DI基础概念关于IoC和DI大家都不陌生,我们直接上martinfowler的原文,里面已经有DI的例子和spring的使用示例《InversionofControlContainer...
- Arthas线上服务器问题排查(arthas部署)
-
1Arthas(阿尔萨斯)能为你做什么?这个类从哪个jar包加载的?为什么会报各种类相关的Exception?我改的代码为什么没有执行到?难道是我没commit?分支搞错了?遇到问题无法在...
- 工具篇之IDEA功能插件HTTP_CLENT(idea2021插件)
-
工具描述:Java开发人员通用的开发者工具IDEA集成了HTTPClient功能,之后可以无需单独安装使用PostMan用来模拟http请求。创建方式:1)简易模式Tools->HTTPCl...
- RPC、Web Service等几种远程监控通信方式对比
-
几种远程监控通信方式的介绍一.RPCRPC使用C/S方式,采用http协议,发送请求到服务器,等待服务器返回结果。这个请求包括一个参数集和一个文本集,通常形成“classname.meth...
- 《github精选系列》——SpringBoot 全家桶
-
1简单总结1SpringBoot全家桶简介2项目简介3子项目列表4环境5运行6后续计划7问题反馈gitee地址:https://gitee.com/yidao620/springbo...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- maven镜像 (69)
- undefined reference to (60)
- zip格式 (63)
- oracle over (62)
- date_format函数用法 (67)
- 在线代理服务器 (60)
- shell 字符串比较 (74)
- x509证书 (61)
- localhost (65)
- java.awt.headless (66)
- syn_sent (64)
- settings.xml (59)
- 弹出窗口 (56)
- applicationcontextaware (72)
- my.cnf (73)
- httpsession (62)
- pkcs7 (62)
- session cookie (63)
- java 生成uuid (58)
- could not initialize class (58)
- beanpropertyrowmapper (58)
- word空格下划线不显示 (73)
- jar文件 (60)
- jsp内置对象 (58)
- makefile编写规则 (58)