当前位置:网站首页>Database basics one (MySQL) [easy to understand]
Database basics one (MySQL) [easy to understand]
2022-08-03 12:34:00 【The whole stack programmer webmaster】
大家好,又见面了,我是你们的朋友全栈君.
数据The library is the study of data management technology.: how to save and manage data scientifically properly.
数据管理是指对数据进行分类、组织、编码、存储、Retrieval and maintenance operations such as.
Data management technology is good or bad judgment standard: (1)数据冗余 (2)数据共享 (3)数据独立性 (4)Data centralized management
数据库: 按一定结构组织存储的、集成的、可共享的数据的集合.
数据库有两种类型:关系型数据库与非关系型数据库.
关系型数据库: 存储格式能直观地反映实体间的关系,和创建的表格比较相似,表与表之间是有复杂的关联关系.
- Oracle 、Mysql 、DB2 、Microsoft SQL Server、 Microsoft Access等
非关系型数据库: 指的是分布式、非关系型的、不保证遵循ACID原则的数据存储系统.
- MongoDb 、 redis 、 HBase、 Cloudant等
使用场景: 1)海量数据存储 2)More data storage format 3)Piece of data format to query speed requirement
关系型数据库
A relational database is a structured collection of data,This structure display in the world of things to use the data model to describe the relationship between. 数据模型——Is said data and model. 数据模型分类(According to the model application of the division of the different purpose of)
概念模型(Also called semantic model) 常用E-R模型
Students and courses is real,Diamond is the corresponding relationships between entities in,Is the corresponding properties of elliptical.
结构数据模型(简称数据模型) 1)层级模型 2)网状模型 3)关系模型等
关系型数据库的数据结构 关系 元组 属性 元数(度、目) 关系模式:The description of the relationship between structure R(A1,A2,A3,…,An) R:关系名 In parentheses is the attribute name
操纵与完整性约束 1)数据操纵: 增、删、改、查
2)Need to meet the integrity of the relationship between constraints: 实体完整性约束 参照完整性约束 用户自定义的完整性约束
A record in a relational database in a number of properties,If some one attribute(组)Can only say a record,该属性(组)You can become a primary key.(primary key)
foreing key (外键)referencesRefer to primary key of the course
关系数据库语言SQL
SQL(Structured Query Language)结构化查询语言:是通用的,Function is extremely strong relationshipDB语言
作用: SQL的数据定义 create database… create table…
SQL的增删改查 SELECT, INSERT, UPDATE, DROP/DELETE
非关系型数据库
非关系型数据库,又称为NoSQL(Not Only SQL)
NoSQL数据库的特点:
1)模式自由 不需要定义表结构,Each record in a data table may have different attributes and format 2)逆规范化 Don't follow the paradigm demands,Remove the integrity constraints,Reduce the dependence between tables 3)弹性可扩展 But in the process of system running,Delete and add dynamic node 4)Copy more asynchronous replication Fast data written to a node,The rest of the nodes by reading log to write To implement asynchronous replication. 5)弱事务 Can't completely meet the transactionACID特性,But can ensure transaction eventually consistent model.
MySQL基础
启动mysql: cmd输入
net start mysql
mysql -uroot -p
标识符和关键字 1)标识符用来命名一些对象,如数据库、表、列、变量等,So that elsewhere in the script reference.MySQLIdentifier command rules a little complicated,Through the naming rules is that:Identifier by with a letter or an underscore(_)开头的字母、数字或下划线序列组成.
2)For identifiers are case-sensitive depends on the operating system,Windows下是不敏感的,但对于大多数linux/Unix系统,This representation is case sensitive.
3)关键字,MySQL的关键字众多,不同版本的MySQLLanguage keywords also slightly change.All the key words have their own special meanings,Should be avoided as identifiers.
Use、求余运算.
Using a comparison operator judgment arithmetic.
运用is null、is not null运算符.
运用“between and”Operator to judge whether a number in a certain range.
运用“in”Operator to judge whether a value within a specified range
运算符“like”,”like”用来匹配字符串,其中“%”匹配任意个字符,“_”匹配一个字符.表达式如下 x1 like s1
与运算:“&&”、“and” 或运算:“||”、“or” 非运算:“!”、“not” 异或运算:“xor”
位运算:|、&、^、~、<<、>>
数学函数:abs,acos,asin,atan,ceiling,cos,degree(Arc to Angle value),floor,greatest(获得一组数中的最大值),least(A number of set the minimum),log,log10,PI,pow,radians(角度值转换为弧度值),rand(返回0~1之间的随机float数),round(返回指定小数的位数的表达式的值),sign(返回某个数的符号),sin(Return units of radian Angle of sine value),sqrt,tan
show databases;语句查看MySQL服务器中的所有数据库
创建数据库:create database if not exists mysqltest;指定字符集为gb2312
All the current existence of the system database:
打开数据库:use test;
修改数据库:alter database mytest;
显示数据库结构:show create database test;
删除数据库:drop database [if exists] db_name;
创建数据库表
create [temporary] table [if not exists] table_name
temporary: arithmetic operators for addition, subtraction, multiplication, and divisionUse the keyword said to create a temporary table if not exists:如果不存在就创建,存在就不执行
Float(3,1)表示精度为4,Decimal is a
设置表的属性自动增加 MySQLIn the database table,An integer column can have an additional propertiesauto_increment,It is a special constraint conditions,Mainly used to insert new records in the table automatic generation of the only sequence coding. 用法: 属性名 数据类型 auto_increment
创建选课表sc,Registration no.sn_noAutomatic incremental,Course selection defaults to the current time,Other fields are student id、Curriculum and teachers.
查看已创建的表:show tables;
查看表结构:describe语句、show create table语句
修改数据库表,语法格式如下: 1)在student表的Email列后面增加一列address
操作完成后,可以执行describeStatements check
- 修改表名:将表sc重命名为se_course.
3)修改字段的数据类型:修改course表的type字段,Make it take a fixed value,“必修”或“选修”默认为“必修”
4)删除字段:删除student表的字段address
Delete existing in the database table,Delete table will delete all data in the table,所以要慎重. drop table table_name
在python数据库中创建表example,然后删除example表.
表记录的插入 1)利用insertCommand to the tablestudent中插入一行数据 2)利用insertCommand to the tablestudent中插入多行数据
利用replaceCommand to the tablecourse中插入多行数据
insert与replace的区别:
insertIf inserted into existing student id to the table(主键)的记录,There will be a primary key conflict error. replace向表中插入数据时,First try to insert data to the list;若发现表中已有此行数据(根据主键或唯一索引判断),Delete any row first, then insert new data,否则直接插入新数据.
使用set子句插入数据 Can't insert data in sequence,To allow null columns can not insert 利用set子句向se_course表插入数据.
用update…set…Command to modify the data of a table 将学号为210010Student course number isc05103The final gradefinal修改为99分
利用delete…from…Statement can delete specified table data from a single table.
基本查询语句 select语句是SQLStatements from the database access to information is a basic statement,Can be realized from one or more of one or more tables in a database query information,并返回结果集.
all是默认值,distinctCancel the result set of duplicate lines. group byFor according to the result of the querygrouping_columns的值进行分组. havingClause is applied to the grouping of the result set additional conditions,与group by一起使用,用于在group byClause after select line. 查询test数据库course表中的所有数据. Query the database tables in the first5条数据
select * from course limit 5;
查询student表中的studentNo、sname和phone数据
单表查询: 在student表中查询出生日期在2001After years of the student's student id、姓名、电话,And for these fields to alias.
在scoreQuery final grade in the table above80 分的学生的学号,And sort by student id,不允许重复(distinct)
查询studentAdmission results in640分以上的学生的学号、姓名信息(where子句的使用)
带in关键字的查询:Query student number respectively210009、210010的学生学号、课程号、期末成绩.
between…and… 查询选修课程号为c05103Student student number and the final grade,Require grades in80-95分之间
用is null关键字查询空值.se_courseTable add performance fieldscore,插入两条记录,查询se_course中成绩为null的学生学号、课程号和成绩.(Whether a field value is empty,要表示为“is null”或“is not null”),不能表示为=null或<>null.如果写成“字段=null”或“字段<>null”,System directly handle asnull值,按照falseProcessing and is not an error.
使用order by子句对结果集排序 在scoreQuery final grade in the table above90分的学生学号、课程号和期末成绩,And according to the first course, ascending order、To score at the end of the schedule of the descending order of
使用group by子句 使用group by子句对scoreTable data packet,According to each student's student number and the average of what they have learned the course final grade,And will the results according to the average of the final grade ascending order
group by和having子句一起使用 Query course in2Above the door each course and the final results were higher than70 Points of each course students student id and the final result of combined result,The query results in descending order according to the grade list.
多表连接
查询选修课程号为c05103的学生的学号、姓名和期末成绩
内连接inner join:By comparing the data source table sharing key column values,Qualified rows from multiple source table retrieval
左外连接Left Outer Join,Use the left outer join query student's student id、姓名、平时成绩和期末成绩.
左外连接left outer join:Return a list of specified left all the line+Corresponding row in the table right,If left the data in the table on the right no matching rows in the table,Another query result set corresponding positions for null values.
右外连接Right Outer Join 右外连接right outer join:Return a list of specified right all lines+The left corresponding row in the table,If the data in the table right in the left no matching rows in the table,Another query result set corresponding positions for null values.
select子句中的子查询 查询学号为210010的学生的姓名、入学成绩、所有学生的平均入学成绩及该学生成绩与所有学生的平均入学成绩的差.
where子句中的子查询:1、With a comparison operator word query 查询期末成绩比选修该课程平均期末成绩低的学生的学号、课程号和期末成绩
where子句中的子查询:带in关键字的子查询 查询期末成绩高于90分的学生的学号、姓名、电话和Email
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/124912.html原文链接:https://javaforall.cn
边栏推荐
- (通过页面)阿里云云效上传jar
- 可重入锁详解(什么是可重入)
- 信创建设看广州|海泰方圆亮相2022 信创生态融合发展论坛
- Vs Shortcut Keys---Explore Different Programming
- Last blog for July
- pandas连接oracle数据库并拉取表中数据到dataframe中、生成当前时间的时间戳数据、格式化为指定的格式(“%Y-%m-%d-%H-%M-%S“)并添加到csv文件名称中
- setTimeout 、setInterval、requestAnimationFrame
- How can I get a city's year-round weather data for free?Precipitation, temperature, humidity, solar radiation, etc.
- R语言拟合ARIMA模型并使用拟合模型进行预测推理、使用autoplot函数可视化ARIMA模型预测结果、可视化包含置信区间的预测结果
- 安防监控必备的基础知识「建议收藏」
猜你喜欢
随机推荐
【Verilog】HDLBits题解——Verification: Writing Testbenches
PolarFormer: Multi-camera 3D Object Detection with Polar Transformers 论文笔记
-树的高度-
基于英雄联盟的知识图谱问答系统
利用ChangeStream实现Amazon DocumentDB表级别容灾复制
3年软件测试经验,不懂自动化基础...不知道我这种测试人员是不是要被淘汰了?
业界新标杆!阿里开源自研高并发编程核心笔记(2022最新版)
信创建设看广州|海泰方圆亮相2022 信创生态融合发展论坛
【必读要点】Pod控制器Deployment更新、回退详解
海外代购系统/代购网站怎么搭建——源码解析
层次分析法
使用工作队列管理器(三)
c语言进阶篇:内存函数
How can I get a city's year-round weather data for free?Precipitation, temperature, humidity, solar radiation, etc.
Simple implementation of a high-performance clone of Redis using .NET (1)
Apache APISIX 2.15 版本发布,为插件增加更多灵活性
使用 %Status 值
Image fusion DDcGAN study notes
基于php旅游网站管理系统获取(php毕业设计)
图像融合GAN-FM学习笔记