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

数据库小知识

AUTO_INCREMENT=100 //设置自增从100开始,不指定长度默认是1(当前表)

SET @@auto_increment_increment=5 //设置每次自增的长度为5,不指定长度默认是1(整个数据库)

CREATE TABLE `grade`(

`GradeID` INT(11) NOT NULL AUTO_INCREMENT COMMENT '年级编号',

`GradeName` VARCHAR(50) NOT NULL COMMENT '年纪名称',

PRIMARY KEY (`GradeID`)

)ENGINE=INNODB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;

//声明自增的字段,定义自增的开始数是6

DEFAULT CHARSET=utf8 :设置默认的字符集(MySQL默认的字符集编码Latin1)

ENGINE=InnoDB:表示创建表时使用InnoDB 存储引擎(默认)

DEFAULT NULL:默认是NULL

CREATE TABLE IF NOT EXISTS `student`( 
'字段名' 列类型 [属性] [索引] [注释], 
'字段名' 列类型 [属性] [索引] [注释], 
...... 
'字段名' 列类型 [属性] [索引] [注释] 
)[表的类型][字符集设置][注释]

列类型/列属性:INT(11)

属性字段:例如NOT NULL DEFAULT '匿名' 

索引字段:PRIMARY KEY (`id`)        //如普通索引、唯一索引、主键索引

约束:

约束(如外键约束、唯一约束等)需要通过 CONSTRAINT 关键字单独定义,且通常写在所有字段定义之后,语法形式为:

CONSTRAINT [约束名] 约束类型 (字段名) 关联规则
例如外键约束:CONSTRAINT FK_xxx FOREIGN KEY (字段) REFERENCES 表(字段)

数据查询语言

基础查询

拼接

SELECT CONCAT('姓名',`StudentName`) AS 新名字 FROM student;

//将CONVAT括号中的东西拼起起来,放到字段名StudentName改为新名字的列下

//其本质是搜索StudentName字段这列

自增

-- 查询自增步长(变量)

SELECT @@auto_increment_increment;

连接查询

左连接左外连接
left joinleft outer join
右连接右外连接
right joinright outer join
全外连接(匹配+不匹配)全外连接(不匹配)
full outer joinfull outer join
内连接

Inner join(join)

分页查询

select 查询列表 from 表 
limit offset,pagesize;

offset:本页的前页有多少条数据

pagesize:每页多少条数据

offset=(n-1)*pagesize

limit n 表示从0到n的页面  //n表示的n条数据

MYSQL函数

SELECT RAND();        //(0,1)之间的小数

SELECT INSERT('我喜欢',1,1,'超级')       //结果:超级喜欢

//1:开始位置 1:去除的长度 (MySQL 中字符串位置从 1 开始计数

SELECT INSTR('zsrs','s');         //结果:2     //返回第一次出现字串索引的位置

SELECT SUBSTR('坚持就是胜利',3,6);        //就是胜利(截取的长度是6,但是现有可被截取的字符串长度为4)

//返回指定的字符串(源字符串,截取位置,截取长度)

http://www.xdnf.cn/news/16731.html

相关文章:

  • vi/vim跳转到指定行命令
  • 下次接好运~
  • 【C#学习Day16笔记】XML文件、 事件Event 、Json数据
  • MySQL学习从零开始--第七部分
  • Linux---make和makefile
  • Linux 用户与组管理:从配置文件到实操命令全解析
  • 一套视频快速入门并精通PostgreSQL
  • SQL中的LEFT JOIN
  • (转)mybatis和hibernate的 缓存区别?
  • “物联网+技校”:VR虚拟仿真实训室的发展前景
  • Python深度解析与爬虫进阶:从理论到企业级实践
  • 微信小程序转Vue2组件智能提示词
  • 汇川ITS7100E触摸屏交互界面开发(一)调试事项说明
  • 把上次做的图片的API改成国内版,让图片返回速度提升一个档次
  • 基于python大数据的招聘数据可视化及推荐系统
  • 解决VScode加载慢、保存慢,git加载慢,windows11系统最近异常卡顿的问题
  • [css]切角
  • 如何解决pip安装报错ModuleNotFoundError: No module named ‘plotly’问题
  • 常见的中间件漏洞如tomcat,weblogic,jboss,apache靶场攻略
  • 机器人学和自动化领域中的路径规划方法
  • 前端工程化包管理器:从npm基础到nvm多版本管理实战
  • 【大模型理论篇】跨语言AdaCOT
  • 详解Vite 配置中的代理功能
  • 企业级部署 (基于tomcat与nginx)
  • SQL理解——INNER JOIN
  • 7月31日作业
  • 大数据之Hive
  • SpringBoot3.x入门到精通系列:1.2 开发环境搭建
  • 本地部署VMware ESXi,并实现无公网IP远程访问管理服务器
  • Linux 服务器性能优化:性能监控,系统性能调优,进程优先级,内核升级全解析