day40

今日内容概要

  • 针对记录的SQL语句

  • 配置文件的介绍

  • 存储引擎的使用(存储的方式)

  • 数据类型(重点)

    • 整型

    • 浮点型

    • 字符串

    • 日期

    • 枚举

针对记录的sql语句

针对库的增删改查(文件夹)
1.创建库
create databases db1;
# 设置库的默认编码
create databases db1 charset='gbk';
2.查看库
# 查看所有库
show databases;
# 查看指定库
show createdatabase db1;
3.改库
alter database db2 charset='utf8';
4.删库
drop database db2;
针对表的增删改查(文件)
1.查看当前所在库的名字
select database();
2.切换到指定库
use database db1;
3.创建表
create table t1(id int,name char(4));
4.查看当前库下面的所有表
# 查看所有的表
show tables;
# 查看指定的表
show create table t1;
# 查看当前表的详细信息
describe t1;
5.修改表
alter table t1 modify name char(16);
6.删除表
drop table t1;
7.以绝对路劲的形式操作不同的库
create table db2.t1(id int);
针对数据的增删改查
1.数据的增加
# 插入单条数据
insert into t1 values(1,'dream');
# 插入多条数据
insert into t1 values(1,'dream')(2,'wu');
2.数据的查看
# 查看全部数据
select * from t1
# 根据指定字段查看数据
select name form t1;
3.数据的更改
# 以限定调价修改指定字段的数据
update t1 set name='wzc' where id > 1;
4.删除数据
# 删除指定字段的数据
delete from t1 where id > 1;
# 删除指定字段的数据
delete from t1 where name='dream';
# 清空当前表的所有数据
delete feom t1;

配置文件的使用

MySQL的配置文件时:my-defaul.int
修改了配置文件,一定别忘了重启服务器端才能生效
把下一段内容加到配置文件中

[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES[client]
default-character-set=utf8[mysql]
default-character-set=utf8

 

存储引擎的使用

日常生活中文件格式有很多,并且针对不同的文件格式会有对应不同的存储方式和处理机制
针对不同的数据应该有对应不同的处理机制
存储引擎就是不同的处理机制

MySQL主要的存储引擎

InnoDB:是MySQL5.5版本之后的默认存储引擎,支持事务、行锁、外键
MyISAM:是MySQL5.5版本之前的默认存储引擎,速度比innodb快,但是数据安全较弱
MEMORY:内存引擎,数据全部存放在内存中,存储速度快,但是断电数据丢失

查看所有数据库存储引擎
show engines;

不同的存储引擎存储数据的异同点

创建表
create table t1(id int) engine=InnoDB;
create table t2(id int) engine=MyISAM;
create table t4(id int) engine=MEMORY;

对于不同的存储引擎,硬盘中保存的文件个数也是不一样的
InnoDB:两个文件
            .frm 存储表结构
            .ibd 存储数据和索引
MyISAM:3个文件
              .frm 存储的是表数据
              .MYD 存储的是表数据
              .MYI 存索引(当成是字典的目录,加快查询速度)
MEMORY:1个文件
                 .frm 存储表结构

数据类型

整型

整型默认情况下都是带符号的
如何去掉符号

create table t1 (id tinyint unsigend)

分类
tinyint smallint int bight
tinyint:它是使用一个字节来保存数据,一个字节代表8位 256种情况(0-256)(-128-127)
smallint:2个字节,代表16位,(0-32768) (-32768-32767)
mediumint:3个字节
int:4个字节,(-2147483648~2147483647)
bigint:8个字节,最大的,可以存手机号

浮点型

float  double decimal
float(255,30)
double(255,30)
decimal(65,39)

他们三个的区别

create table t1 (id float(255,30));
create table t2 (id double(255,30);
create table t3 (id decimal(65,30);insert into t1 values (1.111111111111111111);
insert into t2 values (1.111111111111111111);
insert into t3 values (1.111111111111111111);

结论:三者的精确度不一样:decimal >double > float

字符串

char(4):定长,超过四个字符直接报错,不够四位,使用空格填充
varchar:可变长类型。超出4位,报错,不够4位的,有几位存几位

char与varchar的比较
create table t4(name char(4));
create table t5(name varchar(4));

需设置严格模式才会报错
查看严格模式


mysql> show variables like "%mode";
+----------------------------+------------------------+
| Variable_name              | Value                  |
+----------------------------+------------------------+
| binlogging_impossible_mode | IGNORE_ERROR           |
| block_encryption_mode      | aes-128-ecb            |
| gtid_mode                  | OFF                    |
| innodb_autoinc_lock_mode   | 1                      |
| innodb_strict_mode         | OFF                    |
| pseudo_slave_mode          | OFF                    |
| slave_exec_mode            | STRICT                 |
| sql_mode                   | NO_ENGINE_SUBSTITUTION |
+----------------------------+------------------------+

 设置严格模式

mysql> set global sql_mode='STRICT_TRANS_TABLES';
Query OK, 0 rows affected (0.00 sec)mysql> show variables like "%mode%";
+----------------------------+--------------------------------------------+
| Variable_name              | Value                                      |
+----------------------------+--------------------------------------------+
| binlogging_impossible_mode | IGNORE_ERROR                               |
| block_encryption_mode      | aes-128-ecb                                |
| gtid_mode                  | OFF                                        |
| innodb_autoinc_lock_mode   | 1                                          |
| innodb_strict_mode         | OFF                                        |
| pseudo_slave_mode          | OFF                                        |
| slave_exec_mode            | STRICT                                     |
| sql_mode                   | STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION |
+----------------------------+--------------------------------------------+
8 rows in set (0.00 sec)

 

如需查看是否填充空格需设置严格模式

 set global sql_mode='PAD_CHAR_TO_FULL_LENGTH';mysql> select char_length(name) from t4;
+-------------------+
| char_length(name) |
+-------------------+
|                 4 |
|                 4 |
+-------------------+
2 rows in set (0.00 sec)

 注意:此严格模式会覆盖上一种严格模式,如需两个模式,要逗号添加

set global sql_mode='STRICT_TRANS_TABLES,PAD_CHAR_TO_FULL_LENGTH';
日期
mysql> create table t6(-> id int,-> time1 date,-> time2 datetime,-> time3 time,-> time4 year-> );
Query OK, 0 rows affected (0.03 sec)mysql> insert into t6 values(1,'2023-10-23','2023-10-23 05:19:36','05:19:36',2023);
Query OK, 1 row affected (0.01 sec)mysql> select * from t6;
+------+------------+---------------------+----------+-------+
| id   | time1      | time2               | time3    | time4 |
+------+------------+---------------------+----------+-------+
|    1 | 2023-10-23 | 2023-10-23 05:19:36 | 05:19:36 |  2023 |
+------+------------+---------------------+----------+-------+
1 row in set (0.00 sec)mysql>
枚举
多选一
 关键字enum
mysql> create table t7(id int,hobby enum('sing','jump','rap','basketball'));
Query OK, 0 rows affected (0.04 sec)mysql> insert into t7 values(1,'sing');
Query OK, 1 row affected (0.00 sec)mysql> insert into t7 values(1,'sing1');
ERROR 1265 (01000): Data truncated for column 'hobby' at row 1
mysql> select * from t7;
+------+-------+
| id   | hobby |
+------+-------+
|    1 | sing  |
+------+-------+
1 row in set (0.00 sec)mysql>
多选多
关键字set
mysql> create table t8(id int,hobby set('sing','jump','rap','basketball'));
Query OK, 0 rows affected (0.02 sec)mysql> insert into t8 values(1,'sing,jump');
Query OK, 1 row affected (0.00 sec)mysql> select * from t8;
+------+-----------+
| id   | hobby     |
+------+-----------+
|    1 | sing,jump |
+------+-----------+
1 row in set (0.00 sec)mysql>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/115680.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

01-React入门

React概述 react是什么? React用于构建用户界面的JS库。是一个将数据渲染为HTML视图的开源JS库。 为什么学? 1.原生JS操作DOM繁琐,效率低 2.使用JS直接操作DOM,浏览器会进行大量的重绘重排 3.原生JS没有组件化编码方案,代码…

【Leetcode】 213. 打家劫舍 II ?

你是一个专业的小偷,计划偷窃沿街的房屋,每间房内都藏有一定的现金。这个地方所有的房屋都围成一圈,这意味着第一个房屋和最后一个房屋是紧挨着的。同时,相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚…

sql server2014如何添加多个实例 | 以及如何删除多个实例中的单个实例

标题sql server2014如何添加多个实例 前提(已安装sql server2014 且已有默认实例MSSQLSERVER) 添加新的实例 其实就是根据安装步骤再安装一次(区别在过程中说明) 双击安装 选择“全新独立安装或添加现有功能” 然后下一步下一…

Apache Shiro 1.2.4反序列化漏洞(CVE-2016-4437)

介绍 Apache Shiro是一款开源安全框架,提供身份验证、授权、密码学和会话管理。Shiro框架直观、易用,同时也能提供健壮的安全性。 版本 Apache Shiro 1.2.4及以前版本中 原理 不安全的配置 默认账户在里面 Apache Shiro 1.2.4及以前版本中&#x…

Python 数组和列表:创建、访问、添加和删除数组元素

Python 没有内置支持数组,但可以使用 Python 列表来代替。 数组 本页将向您展示如何使用列表作为数组,但要在 Python 中使用数组,您需要导入一个库,比如 NumPy 库。数组用于在一个变量中存储多个值: 示例&#xff0…

重生奇迹mu宠物带来不一样的体验

重生奇迹mu宠物有什么作用? 全新版本中更是推出了各种宠物,在玩游戏时还可以带着宠物,一起疯狂的刷怪等等,可以为玩家带来非常不错的游戏体验,那么下面就来给大家说说各种宠物适合做什么事情。 1、强化恶魔适合刷怪 …

java头歌-java中的异常

文章目录 第一关第二关第三关第四关 第一关 第二关 题目要求: public static void main(String[] args) {Scanner sc new Scanner(System.in);try {int num1 sc.nextInt();int num2 sc.nextInt();/********* Begin *********/System.out.println(num1/num2);}…

CNN——卷积神经网络

文章目录 多层感知机(MLP,Multilayer Perceptron)神经网络定义MLP与神经网络的异同相同之处:不同之处:总结 为什么要使用神经网络CNN卷积层:池化层:全连接层: 卷积神经网络的优势pad…

Python---while循环的执行流程 解释

使用Debug调试工具&#xff0c;查看while循环的运行流程 代码 # ① 初始化计数器 i 1 # ② 编写循环条件&#xff08;判断计数器是否达到了100&#xff09; while i < 100:print(f{i 1}、老婆大人&#xff0c;我错了)# ③ 在循环体内部更新计数器i 1 ① 代码都是顺序执行…

基于LSTM的天气预测 - 时间序列预测 计算机竞赛

0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 机器学习大数据分析项目 该项目较为新颖&#xff0c;适合作为竞赛课题方向&#xff0c;学长非常推荐&#xff01; &#x1f9ff; 更多资料, 项目分享&#xff1a; https://gitee.com/dancheng-senior/po…

如何为 Elasticsearch 创建自定义连接器

了解如何为 Elasticsearch 创建自定义连接器以简化数据摄取过程。 作者&#xff1a;JEDR BLASZYK Elasticsearch 拥有一个摄取工具库&#xff0c;可以从多个来源获取数据。 但是&#xff0c;有时你的数据源可能与 Elastic 现有的提取工具不兼容。 在这种情况下&#xff0c;你可…

【深蓝学院】手写VIO第7章--VINS初始化和VIO系统--作业

0. 内容 1. T1 1. 下载EuRoc数据集&#xff08;optional&#xff09; 因为作业主要使用Ch2生成的数据&#xff0c;所以这一步也是可选的&#xff0c;但是为了整个系统的bring up&#xff0c;可以先用EuRoc数据集跑起来。 下载EuRoc数据集&#xff0c;SLAM相关数据集链接 2.…

【LeetCode刷题(数据结构与算法)】:数据结构中的常用排序实现数组的升序排列

现在我先将各大排序的动图和思路以及代码呈现给大家 插入排序 直接插入排序是一种简单的插入排序法&#xff0c;其基本思想是&#xff1a; 把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中&#xff0c;直到所有的记录插入完为 止&#xff0c;得到一个…

c语言练习91:合并两个有序链表

合并两个有序链表 力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 代码1&#xff1a; /*** Definition for singly-linked list.* struct ListNode {* int val;* struct ListNode *next;* };*/typedef struct ListNode ListNode; struct Li…

Appium+python+unittest搭建UI自动化框架!

阅读本小节&#xff0c;需要读者具备如下前提条件&#xff1a; 1. 掌握一种编程语言基础&#xff0c;如java、python等。 2. 掌握一种单元测试框架&#xff0c;如java语言的testng框架、python的unittest框架。 3. 掌握目前主流的UI测试框架&#xff0c;移动端APP测试框架Appiu…

应用3之Like运算符的应用

《VBA经典应用69例》&#xff08;10178981&#xff09;&#xff0c;是我推出的第九套教程&#xff0c;教程是专门针对初级、中级学员在学习VBA过程中可能遇到的案例展开&#xff0c;这套教程案例众多&#xff0c;紧贴“实战”&#xff0c;并做“战术总结”&#xff0c;以便大家…

医药电商行业想要精准获客?媒介盒子分享三大技巧

随着医疗需求的不断增长&#xff0c;健康成为社会关注的重点&#xff0c;消费者对医药保健产品和需求正在不断增长&#xff0c;数字化时代的来临使医药行业逐渐电商化&#xff0c;线上零售渠道成为医药行业销售额的主要来源&#xff0c;那当下医药电商行业如何抓住机遇&#xf…

AB试验(六)A/B实验常见知识点的Python计算

AB试验&#xff08;六&#xff09;A/B实验常见知识点的Python计算 前面理论知识上提到了很多的知识点需要计算&#xff0c;作为一个实用主义的博主&#xff0c;怎么可以忍受空谈呢&#xff1f;所以本期就给大家分享如何利用Python对这些知识点进行计算。 均值类指标 import …

一起学数据结构(11)——快速排序及其优化

上篇文章中&#xff0c;解释了插入排序、希尔排序、冒泡排序、堆排序及选择排序的原理及具体代码实现本片文章将针对快速排序&#xff0c;快速排序的几种优化方法、快速排序的非递归进行解释。 目录 1. 快速排序原理解析以及代码实现&#xff1a; 2. 如何保证相遇位置的值一…