【数据库学习】——从零学习SQL语句(含SQL数据类型、SQL语句实例操作)

目录

0、创建数据库

1、调用指定的数据库

2、创建数据表

2.1、SQL数据类型

1).字符型数据:

3).整数型数据

4).精确小数型数据

5).近似数值类型

6).货币型数据

7).位类型数据

2.2 实例创建表

 3、向表中插入

4、主键primary key

5、查询字段

5.1、使用distinct 去除重复值

5.2、使用where来选取指定的数据

 1)常见的where运算符

2)利用and 和 or运算符

3)利用like运算符

4)利用in运算符

 5)利用between运算符

6)order by运算符

6、更新字段update

 7、删除记录delete

 8、index索引用法

9、view视图

 10、NULL值

 11、字段名、表名的别名

 11、join连接

12、子查询

​ 13、常用的统计函数(count、min、max、sum、avg等)

13.1、count——统计指定的字段不为null的记录总数

 13.2、max\min函数——统计所选字段的最大\小值

 13.3、avg——求字段值的平均值

 13.4、sum——对所选字段的记录进行求和

 14、group by分组函数(按照给定的字段进行不同的分组)

 15、having 过滤分组

 16、课后测试


视频学习链接:

从零开始38分钟学会SQL语言_哔哩哔哩_bilibili这个课程是面向零基础的学员,使用38分钟的时间学习了76条经典SQL语句,掌握了SQL语言的基础知识,马上就可以做数据分析了。所有SQL语句均可不加修改地运行在MySQL、Oracle、SQL Server和PostgreSQL等4种数据库上https://www.bilibili.com/video/BV1634y1R77q?from=search&seid=11764788465467756900&spm_id_from=333.337.0.0

前提:下载好mysql数据库,以及配置好mysql环境变量

可参考:【Python项目实战】Python+MySQL开发新闻管理系统全集_哔哩哔哩_bilibili 前几集

0、创建数据库

create database 数据库名;

create database DMS;

注:sql语句不区分大小写

show databases; # 显示所有的数据库

1、调用指定的数据库

use dms;

use 数据库名;

2、创建数据表

create table 数据表名(字段名 字段数据类型 字段长度 其他)

注:分号表示一句完整的SQL的结束

2.1、SQL数据类型

参考:sql数据库常用的几种数据类型 - 小小黑- - 博客园

1).字符型数据

char\varchar\text
这几种数据类型都是用来装字符串的
char         固定长度存储数据(255字节)
varcahr    按变长存储数据
text          当你需要存储非常大量的字符串时使用
nchar、nvarchar、ntext
这几个也是存储字符串的,与上面的对应相同。唯一不同的是这三种类型,是采用Unicode编码,当你做国际化的网站时使用

2).日期时间型数据
datetime、smalldatetime
都是用于存储日期和时间信息
datetime:         存放1/1/1753-12/31/9999的时间数据,精确到0.001s
smalldatetime: 存放1/1/1900-6/6/2079的时间,精确到秒

data:                  

3).整数型数据

用于存放整数
bigint、int、smallint、tinyint
bigint 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字)。
int 从 -2^31 (-2,147,483,648) 到 2^31 - 1 (2,147,483,647) 的整型数据(所有数字)。
smallint 从 -2^15 (-32,768) 到 2^15 - 1 (32,767) 的整数数据。
tinyint 从 0 到 255 的整数数据。

4).精确小数型数据

用于存放小数
decimal、numeric

NUMERIC:型整数部分最大只能有28位,范围为-10^38到10^38之间的数,小数部分的位数必须小于或等于整数部分的位数,小数部分可以是零,定义语法NUNERIC(3,2),表示总位数为3,小数位数为2,如3.14

5).近似数值类型

用于存放近似数
float、real

6).货币型数据

用于存放货币数据
money、smallmoney
在输入货币型数据时要在其前加货币符号,若为负值,则在货币符号后加符号

7).位类型数据

bit
这个刚学不好理解,我给你打个比方吧。比如你的表中有一列放性别,性别只有两种可能性,不是男就是女。这时你就可以把性别这列的数据类型设为bit。凡是与之类似的情况都可以用bit类型数据。

2.2 实例创建表

 create table dept(
    deptno int primary key,
    dname varchar(10),
    loc varchar(10));

 

create table employees(
    empno int primary key,
    name char(10) not null,
     deptno int,
    manager int,
    hiredate date,
    salary numeric(7,2));

 

create table manager(
     empno int primary key,
    itle varchar(16));

 

 3、向表中插入

 show tables; # 显示所有的数据表名

 insert dept values(1,"技术部","一楼A区");

insert dept values(2,"销售部","二楼A区");

insert dept values(3,"行政部","一楼B区");

  insert employees values(1,"张三",1,2,'2011--03-02',4400.00);

 insert manager values(2,'技术部经理');
insert manager values(4,'销售部经理');
insert manager values(5,'行政部经理');
insert manager values(99,'总裁');

4、主键primary key

联合主键:用2个或2个以上的字段组成主键。用这个主键包含的字段作为主键,这个组合在数据表中是唯一,且加了主键索引。

例:

create table grade( 

stuNum char(10) not null,

courseNum  char(10)  not null,

grade  int  not null,

primary key  (stuNum,courseNum))字段 stuNum和courseNum就是联合主键。

 

 总结:

主键是唯一的;

主键可以由多个字段组成;

在同一个表中,主键不可以重复;

修改、插入主键操作不可违反“主键唯一无重复”这个约束

5、查询字段

 

5.1、使用distinct 去除重复值

 

5.2、使用where来选取指定的数据

 1)常见的where运算符

 

2)利用and 和 or运算符

 

3)利用like运算符

指定模式一般为字符串,然后缺省的部分用百分号代替,例如姓刘的,“刘%”

 

4)利用in运算符

等同于:

select 字段名 from 表名 where 字段名 = 值1 or 字段名 = 值2 or ...;

除了使用in,也可以使用not in

 

以下方式可以通过多个表的信息来获取指定条件的数据

 5)利用between运算符

 

6)order by运算符

 

6、更新字段update

 

 7、删除记录delete

 

 8、index索引用法

9、view视图

 

 10、NULL值

 11、字段名、表名的别名

 

 支持中文,使得表更具有可读性

 11、join连接

 

内连接:

 左连接

12、子查询

13、常用的统计函数(count、min、max、sum、avg等)

13.1、count——统计指定的字段不为null的记录总数

 

 13.2、max\min函数——统计所选字段的最大\小值

 

 

 13.3、avg——求字段值的平均值

 13.4、sum——对所选字段的记录进行求和

 

 14、group by分组函数(按照给定的字段进行不同的分组)

group by其实就是先按照group by后面的字段进行分组,然后对每一组利用统计函数进行求解,最后返回每一组的结果,含不同的字段

 

 

 

 15、having 过滤分组

 补充:having和group by结合使用,首先是根据group by进行分组得到不同分组的统计值,然后再过滤掉不符合having条件的分组。

 16、课后测试

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/255650.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

struts2学习笔记(常见错误)

1、由于笔者使用的时最新的struts2 (version 2.5.14.1),之前下载的是all , 一直配置不上,然后查了google才下载的min版本。 这里面有配置struts2需要的必备的jar包,而至于上面的all里面lib里面的jar包实在太多,虽然我…

C#图解教程 第十二章 数组

数组数组定义重要细节数组的类型数组是对象一维数组和矩形数组实例化一维数组或矩形数组访问数组元素初始化数组显式初始化一维数组显式初始化矩形数组快捷语法隐式类型数组综合内容交错数组声明交错数组快捷实例化实例化交错数组比较矩形数组和交错数组foreach语句迭代变量是只…

【数据库学习】——windows、MySQL构建新闻管理系统(控制台版)

学习记录:【Python项目实战】PythonMySQL开发新闻管理系统全集_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1Qb4y1b75q?p2&spm_id_frompageDriver 目录 一、项目介绍 1、项目结构 2、系统部分功能提前展示 3、项目流程图 4、项目设计的数据库以及…

微信红包API接口(PHP)

发布时间:2015年2月25日 / 分类:WEB开发,PHP / 74,825 / 241 ℃ 根据微信高级红包接口,开发PHP版本的API接口,现在进行主要代码分析。 红包接口调用请求代码,所有请求参数为必填参数与文档对应: 1234567891…

2016年个人技术总结(前端)

自我总结 参与项目 备注:[☆-表示比较吊的项目,-从头开始做,^-中间加入项目] 神马生活(微信公众号商城)[^] 神马学院[] <!------跳槽线--------> 大数据套件[☆][^] fable数据营销平台(加入新功能&#xff0c;交互)[^] fit问卷系统[] fit投放系统[] fit画像[^] 理财通点击…

彩色CCD相机工作原理

原理 黑白&#xff08;单色&#xff09;相机 CCD原理并不复杂。我们可以把它想象成一个顶部被打开的记忆芯片。因此光束可以射到记忆单元中。根据"光电效应”&#xff0c;这些光束在记忆单元中产生负电荷&#xff08;下图中右上部分&#xff09;。 曝光后&…

【HTML学习】——HTML常见标签属性和方法介绍

目录 1、HTML分块--------< div> 2、HTML段落--------< p> 3、HTML标题--------< h1>…< h6> 4、HTML链接--------< a> 1)< a href“http://www.baidu.com”>百度< /a>&#xff08;点击百度&#xff0c;直接跳转到网页&#xf…

开发者应警惕的七种糟糕职业规划错误

那些心灵鸡汤式的说辞总爱美化失败&#xff1a;失败是成功之母啦、失败使人成长啦、别畏惧失败等等。但事实上&#xff0c;这种思路在软件开发领域也许并不适用——至少不完全适用。每位开发者在职业生涯中都不可避免会遭遇失败&#xff0c;但为什么不从他人的经验中汲取教训来…

【HTML学习】——一个网页HTML编程的构成

目录 1、html网页构成介绍 2、HTML标签介绍 全部的html标签&#xff1a; HTML: HyperText Markup Language | MDNhttps://developer.mozilla.org/en-US/docs/Web/HTML 一个网页文件一般由.html结尾的文件组成&#xff0c;主要由不同的标签对和内容组成&#xff0c;常见的html…

hbase里插入big int数据用Phoenix查看的报错问题

Phoenix建表create table "test_big_int"("ROW" varchar primary key,"ci"."column1" bigint) 在hbase里put数据hbase 里面进行put: put test_big_int,001,ci:column1,1 在Phoenix里进行查看&#xff08;问题出现&#xff09;第二个尝…

机器学习:利用卷积神经网络实现图像风格迁移 (一)

相信很多人都对之前大名鼎鼎的 Prisma 早有耳闻&#xff0c;Prisma 能够将一张普通的图像转换成各种艺术风格的图像&#xff0c;今天&#xff0c;我们将要介绍一下Prisma 这款软件背后的算法原理。就是发表于 2016 CVPR 一篇文章&#xff0c; “ Image Style Transfer Using Co…

博客园自定义样式

碎碎念&#xff1a; 已经很长时间没有更新过博客了&#xff0c;分析一下&#xff0c;一个是太懒了。。。所以很久没整理一下了。还有就是嫌弃博客园默认的博客界面真的太丑了&#xff0c;作为颜控的我真的无法忍受啊。个人比较喜欢用makedown来编写博客&#xff0c;但是博客园自…

【CSS】——cascading stylesheets层叠式样式表

目录 0、CSS介绍 1、CSS语句组成 2、CSS选择器的选择方式 1&#xff09;CSS选择器的方式和选择器大全&#xff1a; 2&#xff09;常见的三种方式&#xff1a; 3、添加CSS方式 1&#xff09;外部样式表 html调用css代码 css文件 html文件 展示 2&#xff09;内部样式表…

四 Apache Axis2 部署 WebService

最新版本1.7.4发布日期2016-10-21 Axis2官网下载如下文件&#xff1a; axis2-1.6.2-bin&#xff1a;二进制的axis axis2-1.6.2-docs&#xff1a;帮助文档 axis2-1.6.2-war&#xff1a;axis.war 文件 axis2-eclipse-codegen-plugin-1.6.2&#xff1a;Eclipse axis client 插件 a…

安装OpenCV:OpenCV 2.4.8或OpenCV 2.4.9 +VS 开发环境配置

因为读研期间的研究方向是图像处理&#xff0c;所以浅墨这段时间闭门研究了很多OpenCV和图像处理相关的知识与内容。眼看自己积累到一定的程度了&#xff0c;于是决定开始开设这个OpenCV系列专栏&#xff0c;总结自己所学&#xff0c;也分享知识给大家。 好了&#xff0c;这篇文…

powerdesigner中如何在自动生成建表SQL时添加模式名schema

1、在主菜单中选择“模型”→“users and roles”→“users”&#xff0c;新增一个user&#xff0c;其中"name"字段就是要添加的模式名。 2、在新增表时&#xff0c;在表属性的“general”页签中选择"owner"&#xff0c;选择刚才新增的user&#xff0c;即可…

【django学习】——Django介绍和实战(开发简易版博客网页)

目录 0、视频链接 1、环境配置 2、django基本命令 1&#xff09;常见命令 2&#xff09;数据库相关的Django命令 3、Django项目 1&#xff09;Django创建项目 2&#xff09;项目目录介绍 3&#xff09;运行初始化的Django项目 4、Django应用 1&#xff09;Django项目和Djan…

求最大子数组03

题目: 返回一个二维整数数组中最大联通子数组的和。 要求&#xff1a; 1. 输入一个二维整形数组&#xff0c;数组里有正数也有负数。 求所有子数组的和的最大值。要求时间复杂度为O(n)。 2.程序要使用的数组放在一个叫 input.txt 的文件中&#xff0c; 文件格式是: 数组的行…

纠错——【Singleton array array(0.2) cannot be considered a valid collection.】

# 将数据集按照比例划分为训练集和测试集 def split_datas(datas,labels,random_state1,train_size0.9,test_size0.1):train_data, test_data, train_label, test_label sklearn.model_selection.train_test_split(datas,labels,random_staterandom_state,# 作用是通过随机数来…

Android Studio 模拟器 不要皮肤,效果更好

新建或者编辑虚拟机时&#xff0c;皮肤选择“No Skin”即可&#xff0c;第二张图片就是无皮肤的效果&#xff0c;看着更爽啊。 转载于:https://www.cnblogs.com/toSeeMyDream/p/6265501.html