This commit is contained in:
xking 2023-09-07 17:25:32 +08:00
parent 074b2d3453
commit fc4d35fd3f
Signed by: chenkuangwei
GPG Key ID: 931C79A9747F5F82
5 changed files with 424 additions and 3 deletions

View File

@ -1,10 +1,13 @@
## git 基本操作
#### 配置代理
```bash
git config --global http.proxy http://127.0.0.1:7890
git config --global https.proxy ttp://127.0.0.1:7890
```
### 更新git
#### 更新git
```bash
git update-git-for-windows

View File

@ -0,0 +1,54 @@
## hive 删除数据
### 删除表
```sql
-- hive删除表
drop table table_name;
-- 永久性删除,不能恢复:
drop table table_name purge;
```
### 清空数据
```sql
-- hive删除表中数据
truncate table table_name;
-- hive按分区删除数据
alter table table_name drop partition (partition_name='分区名')
```
### 重写数据
与删除条件相反,如删除 date=0528 的数据
那么 重写数 的条件为 date!=0528
**分区表**
```
删除具体partition的部分数据
INSERT OVERWRITE TABLE table_name PARTITION(year='2021')
SELECT * FROM table_name WHERE year='2021' and xx;
```
**非分区表**
```
INSERT OVERWRITE TABLE table_name SELECT * FROM table_name WHERE xx;
```

177
java/Jsr303校验.md Normal file
View File

@ -0,0 +1,177 @@
# JSR303数据校验
JSR303是Java为Bean数据合法性校验提供给的标准框架已经包含在 JavaEE6.0 中、JSR303通过在Bean 属性中标注类似 @NotNull @Max 等标准的注解指定校验规则并通过标准的验证接口对 Bean进行验证
### 注解
### JSR303中含有的注解
```
@Null 被注释的元素必须为 null
@NotNull 被注释的元素必须不为 null
@AssertTrue 被注释的元素必须为 true
@AssertFalse 被注释的元素必须为 false
@Min(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@Max(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@DecimalMin(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@DecimalMax(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@Size(max=, min=) 被注释的元素的大小必须在指定的范围内
@Digits (integer, fraction) 被注释的元素必须是一个数字,其值必须在可接受的范围内
@Past 被注释的元素必须是一个过去的日期
@Future 被注释的元素必须是一个将来的日期
@Pattern(regex=,flag=) 被注释的元素必须符合指定的正则表达式
```
#### Hibernate Validator 附加的注解
```
@NotBlank(message =) 验证字符串非null且长度必须大于0
@Email 被注释的元素必须是电子邮箱地址
@Length(min=,max=) 被注释的字符串的大小必须在指定的范围内
@NotEmpty 被注释的字符串的必须非空
@Range(min=,max=,message=) 被注释的元素必须在合适的范围内
HIbernate Validator是JSR303的一个参考实现除了支持所有标准的校验注解外另外HIbernate Validator还有JSR-380的实现
```
### SpringMVC中使用JSR303进行服务器端验证
a. 添加相关依赖
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator</artifactId>
<version>6.0.7.Final</version>
</dependency>
b. 给校验对象的指定属性添加校验规则
public class User {
private Long userId;
@NotBlank(message = "用户名不能为空")
private String userName;
@NotBlank(message = "密码不能为空")
private String userPwd;
............
}
c. 在请求处理方法中,使用@Validated或@Valid注解要验证的对象并根据BindingResult判断校验是否通过 另外验证参数后必须紧跟BindingResult参数否则spring会在校验不通过时直接抛出异常
public String login(@Validated @ModelAttribute User user,
BindingResult bindingResult){
// 服务器端校验不通过
if (bindingResult.hasErrors()) {
return "login";
}
....
}
注1@Valid和Validated的区别,随便使用哪个都行
@Valid是使用hibernate validation的时候使用
@Validated 是只用spring Validator校验机制使用
### 在JSP页面上通过form标签显示消息
<form:errors path="*" /> 显示表单所有错误
<form:errors path="user* /> 显示所有以user为前缀的属性对应的错误
<form:errors path="username"/> 显示特定表单对象属性的错误
delimiter如果一个属性有多个错误错误信息的分隔符。默认是换行
注1errors标签要放到form标签中才能显示错误消息
注2如果使用form:errors标签不显示错误消息请检查Model中是否已经添加了命令对象没有是不会显示错误消息的
注3注意命名规范Book-->book
@ModelAttribute
public void init(Model model) {
System.out.println("init...");
model.addAttribute("user", new User());
}
### 通过BindingResult和form:errors标签在JSP页面显示非验证消息
public String login(@Valid @ModelAttribute Yh yh, BindingResult bindingResult, Model model){
bindingResult.rejectValue("yhzh", null, "帐号错误");
...
}
bindingResult.rejectValue("email", "validate.email.empty", "邮箱不能为空");//这个函数有好几个重载的变体
它们是可以支持国际化的。 比如,上面这个例子表示, 错误的字段(filed)是“email” errorCode是“validate.email.empty” 与资源文件对应, 第三个是defaultMessage
作业1从BindingResult对象获得错误消息生成基于json字符串返回到客户端
如何实现分组校验
2.1 通过接口定义若干个分组
2.2 给校验对象的指定属性添加校验规则,并指定校验组
2.3 在请求处理方法中,使用@Validated标记要验证的对象,并指定校验组
还可以对验证进行分组(@Validated)
public class Book {
// 书本验证分组
public static interface ValidateGroups {
// 新增/修改
public static interface AddEdit {
}
// 上架/下架
public static interface DeployUndeploy {
}
// 更新封面
public static interface UpdateBookImage {
}
}
private Long bookId;
@NotBlank(message = "书名不能为空", groups = { AddEdit.class })
private String bookName;
private String bookNamePinyin;
@NotNull(message = "类别不能为空", groups = { AddEdit.class })
private Long bookCategoryId;
@NotBlank(message = "作者不能为空", groups = { AddEdit.class })
private String bookAuthor;
@NotNull(message = "价格不能为空", groups = { AddEdit.class })
@Min(value = 1, message = "价格不能为负")
private Double bookPrice;
private Long bookImage;
@NotBlank(message = "出版社不能为空", groups = { AddEdit.class })
private String publishing;
@NotBlank(message = "简介不能为空", groups = { AddEdit.class })
private String bookDesc;
private Integer bookState;
private Date deployDatetime;
private Integer salesVolume;
}
@RequestMapping("/add")
public String add(
@Validated(value = Book.BookGroups.Add.class) @ModelAttribute Book book,
BindingResult bindingResult) {
if (bindingResult.hasErrors()) {
return "admin/addBook";
}
return "admin/addBook";
}
3. 通过分组来指定顺序
@GroupSequence({First.class, Second.class, User.class})

127
linux/fdisk磁盘分区.md Normal file
View File

@ -0,0 +1,127 @@
# fdisk磁盘分区
### Fdisk 命令
```
fdisk [必要参数][选择参数]
```
必要参数
- -l 列出素所有分区表
- -u 与 **-l** 搭配使用,显示分区数目
选择参数
- -s<分区编号> 指定分区
- -v 版本信息
菜单操作说明
- m :显示菜单和帮助信息
- a :活动分区标记/引导分区
- d :删除分区
- l :显示分区类型
- n :新建分区
- p :显示分区信息
- q :退出不保存
- t :设置分区号
- v :进行分区检查
- w :保存修改
- x :扩展应用,高级功能
实例
```
# fdisk -l
Disk /dev/sda: 10.7 GB, 10737418240 bytes
255 heads, 63 sectors/track, 1305 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Device Boot Start End Blocks Id System
/dev/sda1 * 1 13 104391 83 Linux
/dev/sda2 14 1305 10377990 8e Linux LVM
Disk /dev/sdb: 5368 MB, 5368709120 bytes
255 heads, 63 sectors/track, 652 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Disk /dev/sdb doesn't contain a valid partition table
```
新建分区
```
fdisk /dev/sdb
输入 n
按提示操作
最后输入W 保存
```
格式化分区
```
mkfs.ext3 /dev/sdb1
```
格式化磁盘
```
mkfs.ext3 /dev/sdb
```
挂载分区
```bash
/dev/sdb1 /opt ext4 defaults 0 0
```
临时挂载
```bash
mount /dev/sdb1 /Public2
```
### lsblk 命令
查看硬盘信息
```
[root@worker ~]# lsblk
NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT
sda 8:0 0 30G 0 disk
├─sda1 8:1 0 200M 0 part /boot/efi
├─sda2 8:2 0 1G 0 part /boot
└─sda3 8:3 0 28.8G 0 part
├─centos-root 253:0 0 27G 0 lvm /
└─centos-swap 253:1 0 1.8G 0 lvm [SWAP]
sdb 8:16 0 1T 0 disk
└─sdb1 8:17 0 1024G 0 part /opt
sr0 11:0 1 1024M 0 rom
```

60
oracle/oracle.md Normal file
View File

@ -0,0 +1,60 @@
### oracle 数据库 job 操作
**停止job** `force => TRUE` 不检查任务是否正在运行强制停止
```sql
BEGIN
DBMS_SCHEDULER.STOP_JOB(job_name => 'TEST_JOB', force => TRUE);
END;
```
**删除job** `force => TRUE` 不检查任务是否正在运行强制删除
```sql
BEGIN
DBMS_SCHEDULER.DROP_JOB(job_name => 'TEST_JOB');
END;
```
**创建job**
```
BEGIN
DBMS_SCHEDULER.CREATE_JOB (
job_name => 'MC_CH_ISSUE_INFO_CLEAN_NEW',
job_type => 'PLSQL_BLOCK',
job_action => 'BEGIN MC_CH_ISSUE_INFO_CLEAN_EVD; END;',
start_date => SYSTIMESTAMP,
repeat_interval => 'FREQ=DAILY; BYHOUR=8; BYMINUTE=25;',
enabled => TRUE
);
END;
```
停止执行计划
```
BEGIN
DBMS_SCHEDULER.DISABLE('MC_CH_ISSUE_INFO_CLEAN');
END;
```
运行一个计划
```
BEGIN
DBMS_SCHEDULER.RUN_JOB('test_job');
END;
```