使用SQL实现数据操作
SQL和RDBMS的区别:用SQL操作RDBMS
一、数据的完整性




一个汉字占多少长度与编码有关:
UTF-8:一个汉字=3个字节
GBK:一个汉字=2个字节

二、数据库基本操作
1、 登录数据库
首先进入mysql安装目录下的bin文件,然后运行命令:


2、退出登录:quit或者exit
3、 以分号或者\g结束
查看sql版本:select version();

查看当前时间:select now();

修改提示符:prompt 新的提示符

查看创建的数据库:show databases;

查看当前正在使用的数据库:select database(); --NULL值的是空
使用数据库:use demo;

创建数据库:create database 数据库名;

查看数据库的创建语句;show create database 数据库名称;

删除数据库:drop database 数据库名;

指定数据集:create database 数据库名 charset=utf8;

输出Mysql数据库管理系统的性能及统计信息:show table status from 数据库名;

三、数据表基本操作
1、查看当前所使用的表:show tables;
使用该命令前需要使用 use 命令来选择要操作的数据库。

创建表:
create table 数据表名(字段名 字段类型 字段约束[,字段名 字段类型 字段约束])
例:CREATE TABLE student (
id INT UNSIGNED PRIMARY KEY auto_increment,
NAME VARCHAR(10) NOT NULL,
age TINYINT UNSIGNED DEFAULT 0,
high DECIMAL (5, 2) DEFAULT 0.0,
gender enum('男','女','中性','保密') DEFAULT '保密', --枚举值默认从1开始,在使用上是一样的
cls_id INT UNSIGNED NOT NULL );

查看表的创建语句:show create table 表名;

查看表结构:desc 表名 或 show columns from 表名;

显示数据表的详细索引信息,包括PRIMARY KEY(主键):SHOW INDEX FROM 表名:

修改表结构:alter add/modify/change
其中:alter是针对于不存在的字段,例如:添加字段名称
add/modify是针对于已经存在的字段,例如:修改字段类型
change:修改字段名和类型、约束
alter table 表名 add 新加字段 字段约束
例:alter table student add birthday datetime default “2011-11-11 11:11:11”

修改已经存在的字段的类型:
alter table student modify birthday date default "2011-11-11";

修改已经存在的字段名:
alter table student change 旧名称 新名称 date default "2011-11-11";
alter table student change birthday birth date default "2011-11-11";

删除字段:alter table 表名 drop 字段名;
例:alter table student drop birth;

删除表:drop table 表名;
四、数据的增删改查
1、增加insert
(1)全列插入:值与表的字段顺序一一对应
(在实际开发中用的不多,如果表结构一旦发生变化,全列插入就会发生错误)
insert into 表名 values (值1,值2);


(2)指定列插入:
insert into 表名 (列1,列2,……) values (值1,值2,……)
insert into student (name,high,cls_id) values('夏夏',111,2);

(3)多行插入
insert into 表名 (列1,列2,……) values (值1,值2,……), values (值1,值2,……)

2、修改update
update 表名 set 列1=值1,列2=值2 [where 条件]

没有where进行条件限制就是全表更新

4、 删除delete
物理删除:delete from 表名 [where 条件判断]
delete from student; --会删除表内所有内容

where:数据库中常用的是where关键字,用于在初始表中筛选查询。它是一个约束声明,用于约束数据,在返回结果集之前起作用。
group by:对select查询出来的结果集按照某个字段或者表达式进行分组,获得一组组的集合,然后从每组中取出一个指定字段或者表达式的值。
having:用于对where和group by查询出来的分组经行过滤,查出满足条件的分组结果。它是一个过滤声明,是在查询返回结果集以后对查询结果进行的过滤操作。
执行顺序:select –>where –> group by–> having–>order by
五、数据的其它操作
1、UNION :用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中。多个 SELECT 语句会删除重复的数据。
SELECT expression1, expression2, ... expression_n
FROM tables
[WHERE conditions]
UNION [ALL | DISTINCT]
SELECT expression1, expression2, ... expression_n
FROM tables
[WHERE conditions];
参数
expression1, expression2, ... expression_n: 要检索的列。
tables: 要检索的数据表。
WHERE conditions: 可选, 检索条件。
DISTINCT: 可选,删除结果集中重复的数据。默认情况下 UNION 操作符已经删除了重复数据,所以 DISTINCT 修饰符对结果没啥影响。
ALL: 可选,返回所有结果集,包含重复数据。
总结:
UNION 语句:用于将不同表中相同列中查询的数据展示出来;(不包括重复数据)
UNION ALL 语句:用于将不同表中相同列中查询的数据展示出来;(包括重复数据)
SELECT 列名称 FROM 表名称 UNION SELECT 列名称 FROM 表名称 ORDER BY 列名称;
SELECT 列名称 FROM 表名称 UNION ALL SELECT 列名称 FROM 表名称 ORDER BY 列名称;
使用SQL实现数据操作的更多相关文章
- SQL大数据操作统计
SQL大数据操作统计 1:select count(*) from table的区别SELECT object_name(id) as TableName,indid,rows,rowcnt FROM ...
- SQL语言-----数据操作
数据操作 增加数据,insert into 标准格式 insert into 表名 (字段的列表)value(数据列表): 使用set insert into 表名 set 字段1=值,2.....: ...
- SQL语句 - 数据操作
表中数据的变化牵一发而动全身,会同时导致到索引中数据的变化.因此如果查询语句不需要索引,就应该删除无用的索引以提高效率. 一.INSERT语句 1.基本插入语句 insert用于向表中输入数据,其具体 ...
- ODPS SQL <for 数据操作语言DML>
基本操作: 查询: SELECT [ALL | DISTINCT] select_expr, select_expr, ... FROM table_reference [WHERE where_co ...
- MySQL SQL DML (数据操作语言)
包括 SELECT, UPDATE, DELETE, INSERT SELECT 从数据库表中获取数据 用法 SELECT name FROM students; SELECT name,age FR ...
- 数据库_8_SQL基本操作——数据操作
SQL基本操作——数据操作 一.新增数据(两种方案) 方案1: 给全表字段插入数据,不需要指定字段列表,要求数据的值出现的顺序必须与表中设计的字段出现的顺序一致,凡是非数值数据,都需要使用引号(建议是 ...
- SQL不同服务器数据库之间的数据操作整理(完整版)
---------------------------------------------------------------------------------- -- Author : htl25 ...
- 使用Hive或Impala执行SQL语句,对存储在HBase中的数据操作
CSSDesk body { background-color: #2574b0; } /*! zybuluo */ article,aside,details,figcaption,figure,f ...
- 使用Hive或Impala执行SQL语句,对存储在Elasticsearch中的数据操作(二)
CSSDesk body { background-color: #2574b0; } /*! zybuluo */ article,aside,details,figcaption,figure,f ...
随机推荐
- 1、Pycharm中创建项目自动生成头信息
1.打开PyCharm 选择File-Settings 2.模块变量描述,并且重新创建一个.py的文件测试,检测是否自动生成头信息
- 基于4G Cat.1的内网穿透实例分享
上一篇分享了:小熊派4G开发板初体验 这一篇继续BearPi-4G开发板实践:内网穿透实验. 基本TCP的socket通信测试 之前我们学习WiFi模块时,与PC进行TCP协议的socket通信测试我 ...
- videojs兼容ie8
从网上找到很多这个videojs兼容ie8的解决方案,一个一个的试,最后发现没有一个是靠谱的.我好无奈啊…… 先看图(ie上访问必须是线上地址) 看代码: <!DOCTYPE html> ...
- vue页面原样导出excel表格
github地址:https://github.com/wuzhiaite/vue-samples 1.excel导出 做过业务系统的知道,进行涉及到excel的导出,列表数据动则几十万,但是也有一部 ...
- 前端进阶笔记(一)---JS语言通识
一.语言按照语法分类 1.非形式语言:中文 英文 2.形式语言:乔姆斯基谱系(四种文法 上下文包含文法) 0型 无限制文法 1型 上下文相关文法 2型 上下文无关文法 正则文法 二 产生式(BNF) ...
- SpringBoot执行定时任务@Scheduled
SpringBoot执行定时任务@Scheduled 在做项目时,需要一个定时任务来接收数据存入数据库,后端再写一个接口来提供该该数据的最新的那一条. 数据保持最新:设计字段sign的值(0,1)来设 ...
- python数据处理(八)之展示数据
1.前言 1.1.不要擅自假定要讲的故事和数据是一致的,要先研究数据,然后讲述数据研究所得 1.2.讲故事是成为领域专家的重要部分. 1.3.将故事方法: a. 确定想要讲的故事 b.无论选择什么方式 ...
- 数据可视化基础专题(六):Pandas基础(五) 索引和数据选择器(查找)
1.序言 如何切片,切块,以及通常获取和设置pandas对象的子集 2.索引的不同选择 对象选择已经有许多用户请求的添加,以支持更明确的基于位置的索引.Pandas现在支持三种类型的多轴索引. .lo ...
- java 基本语法(八) 数组(一) 数组的概述
* 1.数组的理解:数组(Array),是多个相同类型数据一定顺序排列的集合,并使用一个名字命名, * 并通过编号的方式对这些数据进行统一管理. * * 2.数组相关的概念: * >数组名 * ...
- 渐进式Web应用(PWA)
什么是渐进式Web应用? 渐进式Web应用是一种全新的Web技术,让Web应用和原生APP的体验相近或一致. 渐进式Web应用它可以横跨Web技术及Native APP开发的解决方案,对于开发者的优势 ...