MySQL 详细学习教程【万字长文, 建议收藏】_mysql教程-程序员宅基地

技术标签: 服务器  mysql  javaSE  数据库  

在这里插入图片描述

1. Mysql入门

1.1 Mysql5.7 安装配置

Mysql文档地址

  1. 建议在用户变量下配置
    在这里插入图片描述
  2. 在mysql-5.7.19-winx64目录下创建my.ini文件
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

1.2 命令行连接到Mysql

在这里插入图片描述

1.3 图形化软件

1.3.1 Navicat

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

1.3.2 SQLyog

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
改变字体显示
在这里插入图片描述
在这里插入图片描述

1.4 数据库三层结构

  1. 所有安装Mysql数据库,就是在主机安装一个数据库管理系统(DBMS),这个管理程序可以管理多个数据库。DBMS(database manage system)
  2. 一个数据库中可以创建多个表,以保存数据(信息)。
  3. 数据库管理系统(DBMS)、数据库、表三者之间的关系,如图:
    在这里插入图片描述

2. Java操作数据库、表

2.1 创建数据库

  1. CHARACTER SET:指定数据库采用的字符集,如果不指定字符集,默认utf8;
  2. COLLATE:指定数据库字符集的校对规则(常用的 utf8_bin[区分大小写]、utf8_general_ci[不区分大小写],注意默认是 utf_general_ci)

创建zzw_db02数据库,采用utf8_general_ci校验规则
创建zzw_db03数据库,采用utf8_bin校验规则
在这里插入图片描述
在这里插入图片描述

2.2 查询数据库

在这里插入图片描述

2.3 备份恢复数据库

  • 备份数据库(注意:在DOS执行)命令行

mysqldump -u 用户名 -p -B 数据库1 数据库2 数据库n > 文件名.sql
在这里插入图片描述

  • 恢复数据库(注意:进入mysql命令行再执行)
    在这里插入图片描述
    在这里插入图片描述
  • 备份数据库的表

mysqldump -u 用户名 -p密码 数据库 表1 表2 表n > F:/table.sql

在这里插入图片描述

2.4 创建表

在这里插入图片描述
在这里插入图片描述

2.5 修改表

在这里插入图片描述

3 CRUD

3.1 insert插入

在这里插入图片描述

3.2 update修改

  • 使用细节
    1. UPDATE语法可以用新值更新原有表中的各列;
    2. SET子句指示要修改哪些列和要给予哪些值;
    3. WHERE子句指定应更新哪些行。如没有WHERE子句,则更新所有行;
    4. 如果需要修改多个字段,可以通过 SET 字段1=值1,字段2=值2…

在这里插入图片描述

3.3 delete修改

使用细节
1. 如果不使用where语句,将删除表中所有数据。
2. delete语句不能删除某一列的值(可使用update 设为 null 或者 ’ ’ )
3. 使用delete语句仅删除记录,不删除表本身。如要删除表,使用drop table语句。(即:drop table 表名;)
在这里插入图片描述

3.4 select查询

在这里插入图片描述

  • select语句1
    在这里插入图片描述
  • select语句2
    在这里插入图片描述
  • select语句3
    在这里插入图片描述

3.4.1 模糊查询

在这里插入图片描述

  • order by排序
    在这里插入图片描述
    – 查询加强
    在这里插入图片描述
    在这里插入图片描述

3.4.2 分页查询

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • group by, having, order by, limit 前后顺序在这里插入图片描述

3.5 mysql多表查询

3.5.1 多表查询

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.5.2 自连接

在这里插入图片描述

3.5.3 多行子查询

在这里插入图片描述
在这里插入图片描述

3.5.4 查询临时表

在这里插入图片描述
在这里插入图片描述

3.5.5 all any操作符

在这里插入图片描述
在这里插入图片描述

3.5.6 多列子查询

、

3.5.7 表复制 && 去重

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.5.8 合并查询

在这里插入图片描述

3.6 mysql外连接

左连接右连接区别, 参考
在这里插入图片描述
在这里插入图片描述

3.7 主键

实际开发中,每个表一般都有一个主键
在这里插入图片描述
在这里插入图片描述

3.8 unique

在这里插入图片描述
在这里插入图片描述

3.9 外键

在这里插入图片描述
在这里插入图片描述

  1. 外键指向的表的字段必须是主键或者是unique;
  2. 表的类型是innodb,这样的表才支持外键;
  3. 外键字段的类型要和主键类型一致(长度可以不一致);
  4. 外键字段的值必须在主键中出现过,或者为NULL;(前提是外键字段允许为NULL);
  5. 主外键关系一旦形成,数据不能随便删除了;
    在这里插入图片描述
    在这里插入图片描述

3.91 check

在这里插入图片描述 在这里插入图片描述

3.92 自增长

在这里插入图片描述
在这里插入图片描述

  1. 一般来说自增长是和primary key配合使用的;
  2. 自增长也可以单独使用(需要配合一个unique);
  3. 自增长修饰的字段是整数型的(浮点型也可以,但是使用非常非常少);
  4. 自增长默认从1开始,但也可以通过以下命令修改;
    ALTER TABLE t25 AUTO_INCREMENT = 777;
  5. 如果添加数据时指定增长字段的值,则以指定的值为准,同时下次自增长的会从这个值开始;

3.3错题集

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3. Mysql常用数据类型

整型数据类型 字节数 有符号 无符号
tinyint 1个字节 -2^7~2^7-1 0~2^8-1
smallint 2个字节 -2^15~2^15-1 0~2^16-1
mediumint 3个字节 -2^23~2^23-1 0~2^24-1
int 4个字节 -2^31~2^31-1 0~2^32-1
bigint 8个字节 -2^63~2^63-1 0~2^64-1
float 单精度,4个字节 -2^31~2^31-1 0~2^32-1
double 双精度,8个字节
decimal[M, D] 双精度,8个字节

3.1 数值型( )的基本使用

使用规范:在能够满足要求的情况下,尽量选择占用空间小的类型
在这里插入图片描述

3.2 数值型(bit)的基本使用

bit字段显示时,按照位的方式显示;
查询的时候仍然可以使用添加的数值;
如果一个值只有0,1 可以考虑使用bit(1),可以节约空间;
位类型,M指定位数,默认值1,范围1~64;
在这里插入图片描述

3.3 数值型(小数)的基本使用

  1. FLOAT/DOUBLE [UNSIGNED]
    Float 单精度,Double 双精度
  2. DECIMAL[M,D] [UNSIGNED]
  • 可以支持更加精确的小数位,M是小数位数(精度,小数点前面加小数点后面)的总数,D是小数点(标度)后面的位数;
  • 如果D是0,则值没有小数点(标注:D被省略时,默认是0)。M最大是65,D最大是30.
    建议:如果希望小数的精度高,推荐使用decimal。
    在这里插入图片描述
    在这里插入图片描述

3.4 字符串的基本使用

CHAR(size):固定长度字符串 最大255字符
VARCHAR(size):0~65535字节 可变长度字符串,最大65532字节,1-3个字节用于记录大小【utf8编码size最大21844字符,gbk编码最大32766字符 】

  • 字符串使用细节1
    char(4):这个4表示字符数(最大255),不是字节数,不管中文还是字母都是放4个,按字符计算;
    varchar(4):这个4表示字符数,不管是字母还是中文都以定义好的表的编码来存放数据(gbk、utf8、big5);
  • 字符串使用细节2
    char(4)是定长(固定的大小),就是说,即使你插入’aa’,也会占用分配的4个字符的空间;
    varchar(4)是变长(变化的大小),就是说,如果你插入了’aa’,实际占用空间大小并不是4个字符,而是按照实际占用空间来分配;(varchar本身还需要占用1-3个字节来记录存放的内容长度):L(实际数据大小) + (1-3)字节
  • 细节3
    什么时候使用char,什么时候使用varchar
    如果数据是定长,推荐使用char,比如md5的密码,邮编,手机号,身份证号等;
    如果一个字段的长度不确定,我们使用varchar,比如留言,文章;
    查询速度:char > varchar

3.4.1 文本类型使用细节

存放文本时,也可以使用Text数据类型,可以将TEXT列视为VARCHAR列,注意Text不能有默认值,大小0-2^16字节;
如果希望存放更多字符,可以选择MEDIUMTEXT 0-2^24 或 LONGTEXT 0-2^32
在这里插入图片描述

3.5 日期类型的基本使用

在这里插入图片描述

  • 习题
    在这里插入图片描述

4. 函数

4.1 统计函数 count

在这里插入图片描述

4.2 合计函数 sum

在这里插入图片描述

4.3 合计函数 avg

在这里插入图片描述

4.4 合计函数 max/min

max/min函数返回满足where条件的一列的最大/最小值
在这里插入图片描述

4.5 分组函数 group by

  • 使用group by 子句对列进行分组
  • 使用having 子句对分组后的结果进行过滤
    在这里插入图片描述

4.6 字符串相关函数

在这里插入图片描述
在这里插入图片描述

4.7 数学函数

在这里插入图片描述
在这里插入图片描述

4.8 日期函数

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4.9 加密函数

在这里插入图片描述
在这里插入图片描述

4.12 流程控制语句

在这里插入图片描述
在这里插入图片描述

5. 索引

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5.1 索引类型

  1. 主键索引:主键自动地为主索引(类型:Primary key);
  2. 唯一索引:(unique)
  3. 普通索引:(index)
  4. 全文索引:(fulltext)[适用于MylSAM]
    一般开发中,不适用mesql自带的全文索引;而是使用:全文搜索Solr和ElasticSearch(ES)

5.2 增删改

在这里插入图片描述
在这里插入图片描述

  • 哪些列适合使用索引
    1. 较频繁的作为查询条件的字段应该创建索引;
      比如:select * from emp where empno = 1;
    2. 唯一性太差的字段不适合单独创建索引,即使频繁作为查询条件;
      比如:select * from emp where sex = ‘男’;
    3. 更新非常频繁的字段不适合创建索引
      比如:select * from emp where logincount = 1;
    4. 不会出现在WHERE子句中的字段不该创建索引;

6. 事务

dml: 数据库操纵语言(Data Manipulation language), 以insert, update, delete三种指令为核心,

●什么是事务
事务是用于保证数据的一致性, 它由一组相关的dml语句组成, 该组的dml语句要么全部成功, 要么全部失败. 如: 转账就要用事务来处理, 用以保证事务的一致性.
在这里插入图片描述
●事务和锁
当执行事务操作时(dml语句), mysql会在表上加锁, 防止其它用户修改表的数据

●mysql数据库控制台事务的几个重要操作

  1. start transaction; – 开始一个事务
  2. savepoint 保存点名; – 设置保存点
  3. rollback to 保存点名; – 回退事务
  4. rollback; – 回退全部事务
  5. commit; – 提交事务, 所有的操作生效, 不能回退

在这里插入图片描述

  • 如果直接回退到a点,那么中间的保存点都会被删掉,那就不能再回退到b点
    在这里插入图片描述
    在这里插入图片描述

6.1 注意事项和细节

1.如果不开启事务, 默认情况下, dml操作是自动提交的, 不能回滚.
2.如果开启一个事务, 你没有创建保存点, 你可以执行rollback, 默认就是回退到你事务开始的状态
3.你可以在这个事务还没有提交时, 创建多个保存点, 比如 savepoint aaa;
4.你可以在事务还没有提交前, 选择回退到哪个保存点.
5.mysql的事务机制需要innodb的存储引擎才可以使用, myisam不支持.
6.开始一个事务, start transaction 或者 set autocommit=off 二选一.

6.2 隔离级别

多个连接开启各自事务操作数据库中数据时,数据库系统要负责隔离操作,以保证各个连接在获取数据是的准确性;

脏读(dirty read): 当一个事务读取到另一个事务尚未提交的改变(update、insert、delete)时,产生脏读;
不可重复读(nonrepeata ble read): 同一查询在同一事务中多次进行,由于其它提交事务所做的修改和删除,每次返回不同的结果集,则发生不可重复读;
幻读: 同一查询在同一个事务中多次执行,由于其它提交事务所做的插入操作,每次返回不同的结果集,此时发生幻读;

事务隔离级别定义了事务与事务之间的隔离程度【 可能出现; 不会出现】

Mysql隔离级别 脏读 不可重复读 幻读 加锁读
读未提交(Read uncommitted) 不加锁
读已提交(Read committed) 不加锁
可重复读(Repeatable read) 不加锁
可串行化(Serializable) 加锁

案例: 隔离级别演示

在这里插入图片描述代码

CREATE DATABASE zzw_db02;
USE zzw_db02;

-- 演示mysql的事务隔离级别

-- 1.开启两个mysql控制台

-- 2.查看当前mysql的隔离级别
SELECT @@tx_isolation;

-- mysql> SELECT @@tx_isolation;
-- +-----------------+
-- | @@tx_isolation  |
-- +-----------------+
-- | REPEATABLE-READ |
-- +-----------------+

-- 3.把其中一个控制台的隔离级别设置成 Read uncommitted
SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;

-- 4.创建表
CREATE TABLE `account` (
	id INT,
	`name` VARCHAR(32),
	money INT);
)

1.控制台登录mysql mysql -u root -pzzw
在这里插入图片描述

2.查看并设置控制台-隔离级别: 读未提交. 隔离级别是作用于控制台的
在这里插入图片描述

3.出现脏读
在这里插入图片描述

4.出现不可重复读和幻读
在这里插入图片描述

1.设置控制台-隔离级别: 读已提交
在这里插入图片描述

2.未出现脏读
在这里插入图片描述

3.出现不可重复读和幻读
在这里插入图片描述

1.重新打开,控制台2, 登录mysql, 将 控制台-隔离级别 设置为可重复读, 这样设置隔离级别不会出错
在这里插入图片描述

2.不会出现脏读, 幻读, 不可重复读
在这里插入图片描述


1.重新打开 控制台2, 设置控制台-隔离级别:可串行化
在这里插入图片描述

2.加锁
在这里插入图片描述

代码

-- 查看当前会话的隔离级别
SELECT @@tx_isolation;
-- 查看系统当前隔离级别
SELECT @@global.tx_isolation;
-- 设置当前会话事务隔离级别
SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ
-- 设置系统当前隔离级别
SET GLOBAL TRANSACTION ISOLATION LEVEL REPEATABLE READ
-- mysql默认的隔离级别是可重复读 repeatable read

全局修改mysql事务隔离级别: 修改my.ini配置文件
可选的参数有: read-uncommitted, read-committed, repeatable-read,serializable

[client]
port=3306
default-character-set=utf8
[mysqld]
# 设置为自己MYSQL的安装目录
basedir=D:\zzwmysql\mysql-5.7.19-winx64\
# 设置为MYSQL的数据目录, 这个目录是系统帮我们创建
datadir=D:\zzwmysql\mysql-5.7.19-winx64\data\
port=3306
character_set_server=utf8
#跳过安全检查, 输入错误的用户名和密码也能登陆; 注销后, 需要输入正确的用户名和密码才能登陆
#skip-grant-tables
#设置默认的隔离级别, 如果没有设置隔离级别, 默认repeatable-read
transaction-isolation = read-uncommitted

修改my.ini配置文件后要重启mysql服务才会生效

6.3 事务的acid特性

  1. 原子性(Atomicity)
    原子性是指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生;
  2. 一致性(Consisrtency)
    事务必须使数据库从一个一致性状态变换到另一个一致性状态;
  3. 隔离性(Isolation)
    事务的隔离是多个用户并发访问数据库时,数据库为每一个用户开启的事务,不能被其它事务的操作数据所干扰,多个并发事务之间要相互隔离;
  4. 持久性(Durability)
    持久性是指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,接下来即使数据库发生故障也不应该对数据有任何影响;

6.4 课后作业

1.登录MySQL命令行A, 创建表 dog(id, name), 开始一个事务, 添加两条记录;
2.登录MySQL命令行B, 开始一个事务, 设置为读未提交.
3.A客户端修改Dog 一条记录, 不要提交. 看看B客户端是否看到变化, 说明什么问题?
4.登录mysql客户端C, 开始一个事务, 设置为读已提交, 这时A客户端修改一条记录, 不要提交, 看看C客户端是否看到变化, 说明什么问题?

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

代码

-- 课后作业
USE zzw_db02;

-- 创建Dog表
CREATE TABLE dog (
	id INT,
	`name` VARCHAR(32)
);

7. 存储引擎

  1. MySQL表的类型有存储引擎(Storage Engines)决定,主要包括MylSAM、innoDB、Memory等;
  2. MySQL数据表主要支持六种类型,分别是:CSV、Memory、ARCHIVE、MRG MYISAM、MYISAM、InnoDB;
  3. 这六种又分为两类,一类是“事务安全型(transaction-safe)”,比如InnoDB;其余都属于第二类,称为“非事务安全型(non-transaction-safe)”;
    在这里插入图片描述
  4. MylSAM不支持事务、也不支持外键,但其访问速度快,对事务完整性没有要求;
  5. InnoDB存储引擎提供了具有提交、回滚和崩溃恢复能力的事务安全。但是比起MylSAM存储引擎,InnoDB写的处理效率差一些并且会占用更多的磁盘空间以保留数据和索引;
  6. MEMORY存储引擎使用存在内存中的内容来创建表。每个MEMORY表只实际对应一个磁盘文件,MEMORY类型的表访问非常快,因为它的数据是放在内存中的,并且默认使用HASH索引。但是一旦服务关闭,表中的数据就会丢失掉,表的结构还在。
  • 如何选择存储引擎?
  1. 如果你的应用不需要事务,处理的只是基本的增删改查,那么MyISAM是不二选择;
  2. 如果需要支持事务,则选择InnoDB
  3. Memory存储引擎将数据存储在内存中,由于没有磁盘/IO等待,速度极快。但由于内存存储引擎,所做的任何修改在服务器重启后都将消失;
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

8. 视图

视图是一个虚拟表,其内容由查询定义。同真是的表一样,视图包含列,其数据来自对应的真实表(基表)

在这里插入图片描述

  • 视图的基本使用
    在这里插入图片描述
  • 视图细节

在这里插入图片描述

安全:有些字段是保密的,不能让用户直接看到;
性能:关系型数据库往往会分表存储,建立视图可以避免使用join连接;
灵活:淘汰旧表;

9. mysql用户

mysql中的用户,都存储在数据库mysql的user表中
SELECT host, user, authentication_string FROM mysql.user;
在这里插入图片描述
其中user表的重要字段说明:
1. host:允许登陆的“位置”,localhost表示该用户只允许本机登录,也可以指定ip地址,比如:192.168.1.1
2. user:用户名
3. authentication_string:密码,是通过mysql的password()函数加密之后的密码

  • 创建用户
    create user ‘用户名’@‘允许登陆的位置’ identified by ‘密码’
  • 删除用户
    drop user ‘用户名’@‘登陆的位置’
    在这里插入图片描述

9.1 Mysql权限管理

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
用户root
在这里插入图片描述
用户zzw
在这里插入图片描述

  • 细节
    在这里插入图片描述
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_18817831/article/details/128554013

智能推荐

zhaowei -学习猜拳游戏_机器学习 划拳游戏-程序员宅基地

文章浏览阅读218次。import random# 电脑出拳 电脑产生一个1-3的随机数computer = random.randint(1, 3) # 数字# print(computer)# print(computer)# 我们出拳our = int(input("请出拳(1石头 2 布 3剪刀):")) # 字符串# print(our)# 判断谁输谁赢 orif computer ..._机器学习 划拳游戏

2022年编程语言热度排行榜来啦,快来看看你学习的语言排第几_2022年编程语言排行榜-程序员宅基地

文章浏览阅读4.9k次。一直以来,编程语言都是程序员非常关注的话题。年末将至,是否会有程序员发出疑问——“2022 年行业需求最大的编程语言,花落谁家?”从 2021 年 10 月到 2022 年 11 月,DevJobsScanner 分析了超过 1200 万个开发人员职位。从这 1200 万份工作中,DevJobsScanner 挑选了明确需要编程语言的工作岗位。现在,一起回顾 2022 年行业需求最大的 8 种编程语言。_2022年编程语言排行榜

开发日志[1] 错误:未能找到引用的组件“System.Windows.Forms.DataVisualization”_system.windows.forms.datavisualization netframewor-程序员宅基地

文章浏览阅读696次。错误:未能找到引用的组件“System.Windows.Forms.DataVisualization”原因:代码中是MSChart表格插件未在当前系统中安装。解决:下载对应版本的MSChart.exe安装程序,安装后再次在项目中添加引用即可。相关:......_system.windows.forms.datavisualization netframework 3.5.1

一阶跃函数c语言程序设计教程课后答案,最新整理c语言上机操作题参考.doc-程序员宅基地

文章浏览阅读628次。最新整理c语言上机操作题参考实验一 上机操作初步(2学时)一、实验方式:一人一机二、实验目的:1、了解C语言程序的特点与基本结构。2、了解C语言程序的编译环境。3、掌握使用C语言编写和调试程序的流程:编辑-保存-编译-构建(组件)-执行。4、掌握C语言程序在Visual C++ 6.0环境下的调试过程。5、初步了解C程序的特点。三、实验内容:说明:前三题为必做题目,第四题为选做题目。1、编辑实验..._编写程序,通过输入x的值,计算阶跃函数y的值

使用c++输入字符串和输出字符串的一种方法_c加加中字符串如何一个一个输出-程序员宅基地

文章浏览阅读4.8k次。#include#include//或者#includeusing namespace std;int main(){ char ch[20]; cin>>ch; for(int i=0;i cout}return 0;}_c加加中字符串如何一个一个输出

创建机器人urdf模型并在rviz中展示(利用roboware studio)_5)创建机器人的urdf文件,在rviz中显示并移动机器人。 详细记录移动机器人模型设计-程序员宅基地

文章浏览阅读5k次,点赞9次,收藏44次。注:本文利用roboware studio工具建立urdf模型创建机器人描述功能包右键单击工作空间catkin_ws/src文件夹,点击新建ROS包,将功能包命名为mrobot_description,如下:手动添加功能包依赖项,打开CMakeLists.txt文件,如图所示添加urdf、xacro在功能包中新建四个文件夹,分别为urdf:用于存放机器人模型的urdf或者xacro文..._5)创建机器人的urdf文件,在rviz中显示并移动机器人。 详细记录移动机器人模型设计

随便推点

ES(Elasticsearch)7.6.1安装教程_安装elasticsearch-程序员宅基地

文章浏览阅读5.8k次,点赞4次,收藏21次。ES 安装教程注意:除了最后启动ES的时候在es账户下执行,其他都是在root 下执行的。⼀、前期准备java 11 的安装,请大家自行安装。elasticsearch启动不能以root⽤户运⾏,所以创建es⽤户(root⽤户状态下操作)useradd espasswd es然后输入两次:zong2015如果需要删除用户userdel -r es将elasticsearch⽤户添加到sudoersvim /etc/sudoers..._安装elasticsearch

spring boot>>RabbitMQ中间件发送验证码_basevo依赖-程序员宅基地

文章浏览阅读2.1k次。起因:短信发送的应用场景非常多,在较大的系统中,短信一般作为单独的服务独立运行,而短信发送任务的触发基本有两种方式。1、定时获取Redis中短信发送任务,2、消息中间件订阅短息任务队列。RabbitMQ订阅短信:短信服务:短信服务为独立工程。将阿里云 SmsServer抽取为工具类。1、pom依赖: <!--RabbitMQ-->&..._basevo依赖

uiautomatorviewer拉取手机竖屏却显示为横屏的问题_uiautomatorviewer方向倒了-程序员宅基地

文章浏览阅读2.4k次,点赞3次,收藏3次。uiautomatoruiautomatorviewer拉取手机竖屏却显示为横屏的问题拉取的页面显示解决方法将保存下来的图片进行旋转,旋转为竖屏显示并保存点击open,导入图片和uix格式文件显示正常uiautomatorviewer拉取手机竖屏却显示为横屏的问题拉取的页面显示解决方法点击save将保存下来的图片进行旋转,旋转为竖屏显示并保存点击open,导入图片和uix格式文..._uiautomatorviewer方向倒了

加密技术简介-程序员宅基地

文章浏览阅读1.3w次,点赞7次,收藏32次。参考文章:信息加密技术简介 [浅谈加密技术](https://blog.csdn.net/fanyunda1988/article/details/50897216)加解密简介加解密分类常见的加密技术介绍其余问题,有关于AES 和 RSA 加密技术,对称加密,非对称加密。优点和缺点,以及API会用, 加密的原理。涉及到位运算。让你走一个算法的话你会怎么走? HTTP 和 H..._加密技术

使用迭代器Iterator遍历Collection_.keyset().iterator().next()-程序员宅基地

文章浏览阅读1.1k次。实现LRU算法时,发现使用java的LinkedHashMap时如果删除队头元素(最长时间未访问的元素),需要coll.remove(coll.keySet().iterator().next());因为Map中元素无序,根据key的hashCode()排序,而LinkedHashMap虽然有序,但是无法获取队头和队尾元素,所以只能采用迭代器模式。java.utils包下定义的迭代器接口:Iterator。Iterator对象称为迭代器(设计模式的一种),主要用于遍历 Collection 集合中的_.keyset().iterator().next()

日常Java练习题(每天进步一点点系列)_callable的call方法返回值-程序员宅基地

文章浏览阅读1.5w次,点赞147次,收藏252次。提示:好多小伙伴反映,直接看到答案不太好,那我把答案的颜色设置为透明,答案位置还是在题目后面,需要鼠标选中才能看见(操作如下图),同时为了手机端的小伙伴(手机端也可以长按选中查看),我还会把所有答案放到文章最下面,希望给每天进步一点点的小伙伴更好的体验。前段时间实在是有点忙,抱歉,抱歉,抱歉!!!1、以下二维数组声明合法的是( )正确答案: C 你的答案: C (正确)char[2][3] ch = new char[][]char[2][] ch = new char[][3]char[_callable的call方法返回值

推荐文章

热门文章

相关标签