Oracle问题

本文介绍了如何使用Oracle SQL进行模糊匹配时间查询以及动态获取表字段的属性。首先,展示了如何查询特定月份的产品数据,通过TO_DATE函数和LIKE操作实现模糊匹配。接着,通过JOIN操作结合user_tab_columns和user_col_comments视图,动态获取表的字段名、注释、数据类型和是否可空等信息,并提供了添加额外WHERE条件进行字段模糊匹配的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Oracle问题

1.模糊匹配时间问题

# 查询product表下,2022年7月的数据
# 这里#{time} 替换为‘2022-07’就行啦
Select * from product where TO_DATE(sys_create,'yyyy-MM') like #{time}

2.动态获取表字段属性

SELECT
	ut.COLUMN_NAME,
	--字段名称
	uc.comments,
	--字段注释
	ut.DATA_TYPE,
	--字典类型
	ut.DATA_LENGTH,
	--字典长度
	ut.NULLABLE --是否为空
FROM
	user_tab_columns ut
INNER JOIN user_col_comments uc ON ut.TABLE_NAME = uc.table_name
AND ut.COLUMN_NAME = uc.column_name
WHERE
	ut.Table_Name = 'tableName'
ORDER BY
	ut.column_name

如果想模糊匹配具体的字段,还可以再WHERE条件后面加上

AND (
    ut.COLUMN_NAME LIKE ('%' || '字段名1' || '%')
    OR ut.COLUMN_NAME LIKE ('%' || '字段名2' || '%')
    OR ut.COLUMN_NAME LIKE ('%' || '...' || '%')
)

就可以完成模糊匹配了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值