not+support+wildcard+in+db+name+when+grant+database+level+privilege
时间: 2023-12-12 20:35:19 浏览: 59
根据提供的引用内容,可以得知Oracle数据库在授予数据库级别权限时不支持通配符。也就是说,当你授予数据库级别的权限时,你必须指定一个具体的数据库名称,而不能使用通配符来匹配多个数据库。
例如,在以下语句中,我们试图授予用户“testuser”对所有以“mydb_”开头的数据库的“connect”权限:
```
GRANT CONNECT TO testuser@'%' IDENTIFIED BY 'password' WITH ADMIN OPTION;
GRANT CREATE SESSION TO testuser@'%' IDENTIFIED BY 'password' WITH ADMIN OPTION;
GRANT SELECT ANY TABLE TO testuser@'%' IDENTIFIED BY 'password' WITH ADMIN OPTION;
GRANT INSERT ANY TABLE TO testuser@'%' IDENTIFIED BY 'password' WITH ADMIN OPTION;
GRANT UPDATE ANY TABLE TO testuser@'%' IDENTIFIED BY 'password' WITH ADMIN OPTION;
GRANT DELETE ANY TABLE TO testuser@'%' IDENTIFIED BY 'password' WITH ADMIN OPTION;
```
然而,这样的语句是不被支持的,你必须指定一个具体的数据库名称,例如“mydb_test”。
相关问题
stm32+easyflash+easyflashloger 驱动外部flash 工程
以下是使用EasyFlash和EasyFlashLogger模块驱动外部Flash的示例工程,包括了完整的代码和Makefile文件:
```c
#include "stm32f10x.h"
#include "easyflash.h"
#include "easyflash_logger.h"
#define TAG "main"
#define LOG_BUF_SIZE 1024
void main()
{
// 初始化EasyFlash
if (ef_env_init() != EF_NO_ERR) {
printf("EasyFlash init failed!\n");
return;
}
// 初始化EasyFlashLogger
if (ef_log_init() != EF_NO_ERR) {
printf("EasyFlashLogger init failed!\n");
return;
}
// 写入日志信息
char log_buf[LOG_BUF_SIZE];
snprintf(log_buf, LOG_BUF_SIZE, "This is a log message!");
ef_log_write(log_buf);
// 读取日志信息
size_t log_size;
char *log_data = ef_log_read(&log_size);
printf("Log data: %s\n", log_data);
// 清空日志信息
ef_log_clear();
// 关闭EasyFlashLogger
ef_log_deinit();
}
```
Makefile文件:
```makefile
# 交叉编译工具链
CROSS_COMPILE ?= arm-none-eabi-
# 编译器
CC := $(CROSS_COMPILE)gcc
# 链接器
LD := $(CROSS_COMPILE)gcc
# 链接器脚本
LD_SCRIPT := ld/stm32f103c8t6.ld
# C编译选项
CFLAGS := -I include -Os -std=c99 -ffunction-sections -fdata-sections -mthumb -mcpu=cortex-m3 -DPART_STM32F103C8T6 -DSTM32F10X_MD
# 链接器选项
LDFLAGS := -Wl,--gc-sections -mthumb -mcpu=cortex-m3 -T $(LD_SCRIPT)
# 依赖库
LIBS := -lc -lm -lnosys
# 目标文件
TARGET := app.elf
# 源文件
SRC := $(wildcard *.c) $(wildcard easyflash/*.c) $(wildcard easyflash_logger/*.c)
# 目标文件列表
OBJS := $(patsubst %.c, %.o, $(SRC))
# 默认目标
all: $(TARGET)
# 编译目标文件
%.o: %.c
$(CC) $(CFLAGS) -c $< -o $@
# 链接目标文件
$(TARGET): $(OBJS)
$(LD) $(LDFLAGS) $(OBJS) $(LIBS) -o $@
# 清除编译结果
clean:
rm -rf $(TARGET) $(OBJS)
```
在编译时需要指定交叉编译工具链,并且需要包含EasyFlash和EasyFlashLogger的源文件,以及指定依赖库和链接器脚本。编译完成后,可以将生成的目标文件烧录到STM32芯片中运行。
easyflash+easyflashloger 驱动外部flash 工程
以下是使用EasyFlash和EasyFlashLogger模块驱动外部Flash的示例工程,包括了完整的代码和Makefile文件:
```c
#include <stdio.h>
#include "easyflash.h"
#include "easyflash_logger.h"
#define TAG "main"
#define LOG_BUF_SIZE 1024
void main()
{
// 初始化EasyFlash
if (ef_env_init() != EF_NO_ERR) {
printf("EasyFlash init failed!\n");
return;
}
// 初始化EasyFlashLogger
if (ef_log_init() != EF_NO_ERR) {
printf("EasyFlashLogger init failed!\n");
return;
}
// 写入日志信息
char log_buf[LOG_BUF_SIZE];
snprintf(log_buf, LOG_BUF_SIZE, "This is a log message!");
ef_log_write(log_buf);
// 读取日志信息
size_t log_size;
char *log_data = ef_log_read(&log_size);
printf("Log data: %s\n", log_data);
// 清空日志信息
ef_log_clear();
// 关闭EasyFlashLogger
ef_log_deinit();
}
```
Makefile文件:
```makefile
# 交叉编译工具链
CROSS_COMPILE ?= /opt/xtensa-lx106-elf/bin/xtensa-lx106-elf-
# 编译器
CC := $(CROSS_COMPILE)gcc
# 链接器
LD := $(CROSS_COMPILE)ld
# 链接器脚本
LD_SCRIPT := ld/eagle.app.v6.ld
# C编译选项
CFLAGS := -I include -Os -std=c99 -ffunction-sections -fdata-sections -mlongcalls -mtext-section-literals -D__ets__ -DICACHE_FLASH
# 链接器选项
LDFLAGS := -nostdlib -Wl,--no-check-sections -u call_user_start -Wl,-static -Wl,--gc-sections -T $(LD_SCRIPT)
# 依赖库
LIBS := lib/libmain.a lib/libhal.a lib/libphy.a lib/libpp.a lib/libnet80211.a lib/liblwip.a lib/libwpa.a lib/libcrypto.a lib/libssl.a lib/libsmartconfig.a
# 目标文件
TARGET := app.out
# 源文件
SRC := $(wildcard *.c) $(wildcard easyflash/*.c) $(wildcard easyflash_logger/*.c)
# 目标文件列表
OBJS := $(patsubst %.c, %.o, $(SRC))
# 默认目标
all: $(TARGET)
# 编译目标文件
%.o: %.c
$(CC) $(CFLAGS) -c $< -o $@
# 链接目标文件
$(TARGET): $(OBJS)
$(LD) $(LDFLAGS) $(LIBS) $(OBJS) -o $@
# 清除编译结果
clean:
rm -rf $(TARGET) $(OBJS)
```
在编译时需要指定交叉编译工具链,并且需要包含EasyFlash和EasyFlashLogger的源文件,以及指定依赖库和链接器脚本。编译完成后,可以将生成的目标文件烧录到ESP8266/ESP32芯片中运行。