当前位置: 首页 > news >正文

SQL笔记

最近的工作对SQL的应用程度较高,而且写的sql类型基本没怎么涉及过,把用到的几个关键字记录下。

使用环境:达梦数据库
达梦数据库有个特点,他有一个叫模式的说法,在图形化工具里直接点击创建查询窗口,不用像sqlserver一样,需要选择所属表的库,但是执行查询的时候,要在查询表的前面加上模式名,模式名.table ,在使用的时候倒是没啥影响,就是需要多打几个字。可以理解成Oracle中的实例。

  1. concat(’ ‘,’ ‘,’ ')——拼接文字和数据字段用,放在select后。

select concat(’ 测试’,id,‘z3’) from table
id=1的情况,输出数据为
测试1z3

  1. datepart(mm, 字段)—— 提取日期中的年、月、日、小时、分钟等,yy/mm/dd代表提取年/月/日,可用在select后生成新的一列,或者在where后面当做查询条件。

select datepart(mm,date) from table
查询此表中date字段的月份数据。

  1. round(字段名,2) ——保留字段值指定小数位数,四舍五入。示例为保留两位。

select round(shuzi,2) from table
设定shuzi列为2.145674,查询结果为 2.14

  1. convert(nvarchar,convert(decimal,字段)) ——转换字符串类型,基础命令为convent(数值类型,字段名),示例为将字段转换成decimal(精度更高的数值类型创建时需定义总数),然后再转换成varchar,这么写的原因是,如果直接转换成varchar类型,在concat()拼接函数里显示的科学计数法,而非准确的数值。
  2. +,-,*,/ 四则运算,直接在两个字段间用就可以。
  3. DateAdd(year,-1,date)——将日期字段减去一年显示。目前是在where后使用。

select * from a left join b on a.id=b.id where a. DateAdd(year,-1,a.date)=b.date
a和b是同一个表。这么写的目的是对比今年和去年在同一时期的数据。

  1. 这个函数分为两部分。
    month()、year()、day() 返回指定日期字段的月,日,年。
    getdate(),获取当前系统日期。
    month(date)=month(getdate()) ——当月数据
    year(date)=year(getdate()) ——当年数据
    day(date)=day(getdate()) ——当天数据

select * from table where year(date)=year(getdate())-1 and month(date)=month(getdate())
此条sql为查询本月去年的数据。

  1. left join 1=1 将要查询的两个表结果拼接。

这个地方理解的不是很透彻,但是拼接效果是达到我的预期了,后面理解下cross join
https://qa.1r1g.com/sf/ask/2476240231/

  1. having 用在group by 后面,对group by 分组后数据进行筛选。

力扣做题参考别人的答案看到的,实际应用较少,仍需进一步理解
having对组,where对行。
https://blog.csdn.net/qq_37634156/article/details/120055284

参考文章

SQL Server 数据库之日期和时间函数
https://blog.csdn.net/weixin_43960383/article/details/124596591

http://www.lryc.cn/news/124610.html

相关文章:

  • UHPC的疲劳计算——兼论ModelCode2010的适用性
  • 关于elementui的input的autocomplete的使用
  • 即然利用反射机制可以破坏单例模式,有什么方法避免呢?
  • 【IDEA问题】下载不了源代码
  • 代码随想录第四十八天
  • 书写自动智慧:探索Python文本分类器的开发与应用:支持二分类、多分类、多标签分类、多层级分类和Kmeans聚类
  • 前端Webpack面试题
  • LabVIEW使用边缘检测技术实现彩色图像隐写术
  • 第一次参加计算机会议报告注意事项以及心得
  • TypeScript教程(二)基础语法与基础类型
  • 问道管理:网上如何打新股?
  • 重磅更新,HertzBeat 集群版发布,易用友好的开源实时监控系统!
  • .NET6使用微信小程序授权登录,获取手机号
  • 游戏类APP如何提升用户的活跃度?
  • 【Sklearn】基于支持向量机算法的数据分类预测(Excel可直接替换数据)
  • 抽象类与接口
  • 第三章,矩阵,09-线性方程组解的判断与求法、矩阵方程
  • Vue-4.编译器VsCode
  • Neo4j之Aggregation基础
  • Python 函数
  • Spring(三):Spring中Bean的生命周期和作用域
  • 【AutoLayout案例03-设置底部按钮之间相同间距 Objective-C语言】
  • 代码随想录算法训练营20期|第七天|哈希表part02|454.四数相加II ● 383. 赎金信 ● 15. 三数之和 ● 18. 四数之和 ● 总结
  • NavMeshPlus 2D寻路插件
  • 【03】基础知识:typescript中的函数
  • ssm社区文化宣传网站源码和论文
  • Go语言工程实践之测试与Gin项目实践
  • 排查docker无法启动问题
  • [C++ 网络协议] 套接字和地址族、数据序列
  • AI 绘画Stable Diffusion 研究(八)sd采样方法详解