SQL数据库 表的创建与基本操作 sql数据库 表的创建与基本操作是什么
wptr33 2024-12-26 17:07 32 浏览
1、创建表:
关键字(保留字)CREATE TABLE
例子一:教师表
CREATE TABLE teacher ( teacher_id varchar(50) not null, teacher_name varchar(100) not null default'', gender varchar(10) not null default 'F', );
例子二:班级表
CREATE TABLE class ( class_id varchar(50) not null, class_name varchar(100) not null default'' );
例子三:学生表
CREATE TABLE student ( student_id varchar(50) not null, student_name varchar(100) not null default'', gender varchar(10) not null default'', age integer not null default 0, class_id varchar(50) not null default'' )
2、表的修改操作:
更新表:RENAME TABLE 旧表名 TO 新表名;更新字段名:ALTER TABLE 表名 CHANGE 旧字段名 新字段名 字段类型;更新字段类型、NULL值、默认值:ALTER TABLE 表名 MODIFY 字段名 新字段类型;删除字段默认值:ALTER TABLE 表名 ALTER COLUMN 字段名 DROP DEFAULT;设置主键:ALTER TABLE 表名 ADD PRIMARY KEY(主键字段列表);删除主键:ALTER TABLE 表名 DROP PRIMARY KEY;新增字段:ALTER TABLE 表名 ADD COLUMN 新字段名 字段类型及其他属性;删除字段:ALTER TABLE 表名 DROP COLUMN 字段名;删除表:DROP TABLE 表名;克隆表:SELECT * INTO teacher_bak FROM teacher;(方法一) CREATE TABLE teacher_bak AS SELECT *FROM teacher(方法二) (以表名teacher为例)
插入整行字段:INSERT INTO teacher VALUES ('T0001','高齐妍','男');(方法一) INSERT INTO teacher(teacher_id,teacher_name,gender) VALUES ('T0001','高齐妍','男');(方法二更安全)
3、查询数据:SELECT 字段列表 FROM 表名;
SELECT teacher_id FROM teacher;
SELECT teacher_id,teacher_name,gender FROM teacher;
4、排序返回结果:SELECT 字段列表 FROM 表名
ORDER BY 字段1[ASC/DESC],字段2[ASC/DESC]...; (ASC升序,DESC降序)
按age升序排列:SELECT class_id,student_id,student_name,gender,birth_day,age FROM student ORDER BY age ASC; #等价写法如下: SELECT class_id,student_id,student_name,gender,birth_day,age FROM student ORDER BY age;
按age和student_name升序排列:SELECT class_id,student_id,student_name,gender,birth_day,age FROM student ORDER BY age ASC,student_name ASC; #等价写法如下: SELECT class_id,student_id,student_name,gender,birth_day,age FROM student ORDER BY 6 ASC,3 ASC; #6和3表示排在第6和排在第3的字段
返回前几行:关键字LIMIT
写法:
SELECT 字段列表 FROM 表名 LIMIT 10;#返回查询结果的前10行
返回中间几行:关键字 LIMIT M OFFSET N (从第N行开始,返回M行记录)
两种写法:
SELECT 字段列表 FROM 表名 LIMIT M OFFSET N;
SELECT 字段列表 FROM 表名 LIMIT N,M;
特例:SELECT 字段列表 FROM 表名 LIMIT 0,10;等价于
SELECT 字段列表 FROM 表名 LIMIT 10;
返回后几行:TOP、LIMIT
举例:
第1步:先按学生编号倒序排序;
第2步:返回排序后的前5行;
第3步:将前5行数据升序排序;
SELECT *FROM ( SELECT TOP 5 * FROM student ORDER BY student _id DESC )a ORDER BY student_id ASC
5、过滤数据:关键字WHERE
SELECT 字段列表 FROM 表名 WHERE 过滤条件:
例子:
SELECT student_id,student_name FROM student WHERE gender='男';
SELECT *FROM student WHERE age<>10;
过滤NULL值:
例子:
SELECT *FROM student WHERE student_id NOT IN('S20160001','S20160002');
SELECT *FROM student WHERE class IS NULL;
关键字BETWEEN:
例子:
SELECT *FROM student WHERE student_id NOT IN('S20160001','S20160002');
关键字IN(包含)、NOT IN(不包含):
例子:
SELECT *FROM student WHERE student_id NOT IN('S20160001','S20160002');
SELECT *FROM student WHERE student_id NOT IN('S20160001','S20160002');
SELECT *FROM student WHERE student_id NOT IN('S20160001','S20160002');
6、高级过滤数据:
(1)、使用通配符过滤数据:关键字LIKE
百分号% 匹配0~多个任意字符
下划线_ 匹配1个任意字符
方括号[]、[^] 匹配1个字符集中的字符 #MySQL不支持方括号
例子:
SELECT *FROM student WHERE student_name LIKE '陈%'; #选出学生中姓陈的同学
SELECT *FROM student WHERE student_name LIKE '刘_'; #选出学生中姓刘且名字只有两个字的同学
SELECT *FROM student WHERE student_name LIKE '%慧'; #选出学生中名字里有慧字的同学
以下两句不支持在MySQL中查询:
SELECT *FROM student WHERE student_id LIKE 'S200[678]'; #选出学生中学号为S2006、S2007、S2008的同学
SELECT *FROM student WHERE student_id LIKE 'S200[^678]'; #选出学生中学号不为S2006、S2007、S2008的同学
使用通配符的注意点:
不要过度使用通配符;
如果确实需要使用,也尽量不要把通配符用在匹配模式的开始处;
要特别注意通配符的位置,否则很有可能返回的结果与预期不一致。
相关推荐
- Java常用工具类技术文档(java常用util工具类)
-
一、概述Java工具类(UtilityClasses)是封装了通用功能的静态方法集合,能够简化代码、提高开发效率。本文整理Java原生及常用第三方库(如ApacheCommons、GoogleG...
- 建议收藏!深入理解Java虚拟机:JVM垃圾回收算法+垃圾收集器
-
02JVM垃圾回收算法2.1什么是垃圾回收?...
- Java 开发者线上问题排查常用的 15 个 Linux 命令
-
作为Java开发者,线上环境的问题排查是日常工作的重要组成部分。熟练掌握Linux命令能大幅提升排查效率,快速定位进程异常、日志错误、性能瓶颈等核心问题。本文结合Java应用特点,整理1...
- Java-Maven详解(maven for java)
-
一、什么是Maven?ApacheMaven是一个软件...
- java 文件操作(I/O流)(java文件流写入文件)
-
一、文件操作技术演进二、核心类对比分析...
- 如何使用Java API操作HDFS系统?(java编程操作hdfs能完成的功能有)
-
1.搭建项目环境打开Eclipse选择FileàNewàMavenProject创建Maven工程,选择“Createasimpleproject”选项,点击【Next】按钮,会进入“New...
- 那些被"删除"却仍占用空间的文件
-
在服务器运维过程中,磁盘空间不足是一个常见问题。而有时候,即使清理了大量文件,系统仍然报告磁盘几乎已满,这种情况尤为令人困惑。本文将通过一个实际案例,分享如何排查和解决Linux服务器上的"幽...
- SpringBoot的Web应用开发——Web缓存利器Redis的应用!
-
Web缓存利器Redis的应用Redis是目前使用非常广泛的开源的内存数据库,是一个高性能的keyvalue数据库,它支持多种数据结构,常用做缓存、消息代理和配置中心。本节将简单介绍Redis的使...
- Redis 常用命令大全(redis常用命令及详解)
-
Redis常用命令全解析在当今的数据处理与存储领域,Redis凭借其高性能、丰富的数据结构等特性,成为了众多开发者和企业的首选内存数据库。下面将为大家详细介绍Redis的常用命令。键(Key)...
- Redis+Lua脚本防超卖是万能解?这3个致命漏洞你可能没发现!
-
在高并发秒杀场景中,Redis+Lua脚本常被视为防止超卖的“银弹”。然而,许多开发者因对其底层逻辑理解不足,踩中了致命漏洞却不自知。本文通过真实案例剖析三个隐藏极深的问题,并提供完整解决方案,助你避...
- 10w qps缓存数据库——Redis(缓存技术 redis)
-
一、Redis数据库介绍:Redis:非关系型缓存数据库...
- Redis安装及核心数据结构(redis一般安装在哪)
-
Redis安装官方下载地址:http://redis.io/downloadhttp://download.redis.io/releases/...
- Python Redis数据库新玩法:从零到高手掌握操作技巧
-
介绍Redis(RemoteDictionaryServer)是一种高性能的开源内存数据库,它支持多种数据结构,如字符串、哈希、列表、集合、有序集合等,并提供了丰富的操作命令。Redis具有快速、...
- redis知识总结(基础篇,可复习,可学习)
-
最近redis差不多看完了,前面学的也忘了好多,所以正好写篇博客复习复习。此篇介绍的是redis的基础篇,希望这篇能帮到各位大佬。...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
git pull命令使用实例 git pull--rebase
-
面试官:git pull是哪两个指令的组合?
-
git 执行pull错误如何撤销 git pull fail
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
-
- Java常用工具类技术文档(java常用util工具类)
- 建议收藏!深入理解Java虚拟机:JVM垃圾回收算法+垃圾收集器
- Java 开发者线上问题排查常用的 15 个 Linux 命令
- Java-Maven详解(maven for java)
- java 文件操作(I/O流)(java文件流写入文件)
- 如何使用Java API操作HDFS系统?(java编程操作hdfs能完成的功能有)
- 那些被"删除"却仍占用空间的文件
- SpringBoot的Web应用开发——Web缓存利器Redis的应用!
- 如何使用C#中的Lambda表达式操作Redis Hash结构,简化缓存中对象属性的读写操作
- Redis 常用命令大全(redis常用命令及详解)
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)