数据库学习之简单的SQL语句
1、数据库的结构
1.1数据库
不同数据库叫做Catalog(在有的 DBMS 中也称为 Database,即数据库) 。採用多 Catalog 以后能够给我们带
来例如以下优点:
便于对各个 Catalog 进行个性化管理。
DBMS 都同意我们指定将不同的 Catalog 保存在不
同的磁盘上, 因为人力资源数据相对次要一些, 因此我们能够将 HR 保存在普通硬盘上。
而将 BIZ 保存在 RAID 硬盘上。 我们还能够对每一个 Catalog 所能占领的最大磁盘空间、日
志大小甚至优先级进行指定,这样就能够针对不同的业务数据进行个性化定制了。
避免了命名冲突。同一个 Catalog 中的表名是不同意反复的,而不同 Catalog 中的表名
则是能够反复的。这样 HR 中能够有 Persons 表,而 BIZ 中也能够有 Persons 表,二者结
构能够全然不同样。保存的数据也不会互相干扰。
安全性更高。DBMS 同意为不同的 Catalog 指定不同的用户,而且能够限定用户能訪问
的 Catalog。比方用户 hr123 仅仅能訪问 HR,而用户 sales001 仅仅能訪问 BIZ。这就大大加
强了系统数据的安全性。
1.2表
解决问题的方法就是将不同类型的资料放到不同的 “区域” 中,我们将这样的区域叫做 “表”( T able)。
1.2.1列字段
1.2.2记录
2数据的增删改
2.1建表语句
(1)CREA TE T ABLE T_Person (FName VARCHAR(20),FAge INT ,FRemark VARCHAR(20),PRI MARY
KEY (FName));
(2)CREA TE T ABLE T_Debt (FNumber V ARCHAR(20),FAmount DECIMAL(10,2) NOT NULL,
FPerson VARCHAR(20),PRIMARY KEY (FNumber),
FOREIGN KEY (FPerson) REFERENCES T_Person(FName)) ;
2.2数据的插入
2.2.1简单的 INSERT 语句
INSERT INTO T_Person(FName,FAge,FRemark) VALUES('T om',18,'USA')
须要注意的是 V ALUES 前列出的字段名和 VALUES 后边列出的字段值是按顺序一一相应的。
2.2.2简化的 INSERT 语句
INSERT 语句中也并不须要我们指定表中的全部列,比方在插入数据的时候某些字段没
有值,我们能够忽略这些字段。以下我们插入一条没有备注信息的数据:
INSERT INTO T_Person(FAge,FName) VALUES(22,'LXF')。
INSERT 语句还有还有一种使用方法。能够不用指定要插入的表列,这样的情况下将依照定义表
中字段顺序来进行插入,我们运行以下的 SQL:
INSERT INTO T_Person VALUES('luren1',23,'China')。
2.2.3非空约束对数据插入的影响
正如“非空约束” 表达的意思, 假设对一个字段加入了非空约束, 那么我们是不能向这
个字段中插入 NULL 值的。T_Debt 表的 F Amount 字段是有非空约束的,假设我们运行以下
SQL:
INSERTINTO T_Debt (FNumber , FPerson) V ALUES ('1', 'Jim') 。
2.2.4主键对数据插入的影响
主键是在同一张表中必须是唯一的, 假设在进行数据插入的时候指定的主键与表中已有
的数据反复的话则会导致违反主键约束的异常。
2.2.5外键对数据插入的影响
外键是指向还有一个表中已有数据的约束, 因此外键值必须是在目标表中存在的。 假设插
入的数据在目标表中不存在的话则会导致违反外键约束异常。
2.3 数据的更新
2.3.1简单的数据更新
UPDATE 语句用来对数据表中的数据进行更新。UPDATE T_Person SET FRemark = 'SuperMan' 。
UPDATE T_PersonSET FRemark = 'Sonic', FAge=25 。
2.3.2带 WHERE 子句的 UPDATE 语句
UPDATE T_Person SET FAge = 12 WHERE FNAME='T om' 。
UPDATE T_Person SET FAge = 22 WHERE FName='jim' OR FName='LXF' 。
2.3.2主键对数据更新的影响
主键是在同一张表中必须是唯一的。 假设在进行数据更新的时候指定的主键与表中已有
的数据反复的话则会导致违反主键约束的异常。
2.3.3外键对数据更新的影响
外键是指向还有一个表中已有数据的约束, 因此外键值必须是在目标表中存在的。 假设更
新后的数据在目标表中不存在的话则会导致违反外键约束异常。
2.4数据的删除
数据库中的数据一般都有一定的生命周期,当数据不再须要的时候我们就要将其删除,
运行 DELETE 语句就能够将数据从表中删除。
只是须要注意的就是假设被删除的数据行是某
个外键关联关系中的被引用数据的话, 则进行删除的时候会失败。 假设要删除成功则必须首
先删除引用者才干够。
2.4.1简单的数据删除
DELETE FROM T_Debt; DELETE FROM T_Person;
不过 DELETE 语句不过删除表中的数据行。 而表的结构还存在。 而 DROP T ABLE 语句则不仅将表中的数据行所有删除,并且还将表的结构也删除。DELETE 语句也提供了 WHERE 语句进行数据的过滤,这样唯独符合过滤条件的数据行才会被删除。
2.4.2带 WHERE 子句的 DELETE 语句
DELETE FROM T_Person WHERE FAge > 20 or FRemark = 'Mars' 。
DROP TABLE T_Debt;
DROP TABLE T_Person;
数据库学习之简单的SQL语句的更多相关文章
- 数据库学习(三) sql语句中添加函数 to_char,round,连接符||
** to char 是把日期或数字转换为字符串 to date 是把字符串转换为数据库中得日期类型 参考资料:https://www.cnblogs.com/hllnj2008/p/533296 ...
- 吴裕雄--天生自然ORACLE数据库学习笔记:优化SQL语句
create or replace procedure trun_table(table_deleted in varchar2) as --创建一个存储过程,传入一个表示表名称的参数,实现清空指定的 ...
- MyBatis学习 之 二、SQL语句映射文件(2)增删改查、参数、缓存
目录(?)[-] 二SQL语句映射文件2增删改查参数缓存 select insert updatedelete sql parameters 基本类型参数 Java实体类型参数 Map参数 多参数的实 ...
- MyBatis学习 之 二、SQL语句映射文件(1)resultMap
目录(?)[-] 二SQL语句映射文件1resultMap resultMap idresult constructor association联合 使用select实现联合 使用resultMap实 ...
- (转载)异构数据库之间完全可以用SQL语句导数据
<来源网址:http://www.delphifans.com/infoview/Article_398.html>异构数据库之间完全可以用SQL语句导数据 告诉你一个最快的方法,用SQL ...
- [20190328]简单探究sql语句相关mutexes.txt
[20190328]简单探究sql语句相关mutexes.txt --//摘要:http://www.askmaclean.com/archives/understanding-oracle-mute ...
- 四种简单的sql语句(增删改查语句)
四种简单的sql语句(增删改查语句) 一.插入语句 insert into [table] ([column],[column],[column]) values(?,?,?) 二.删除语句 dele ...
- tp5 r3 一个简单的SQL语句调试实例
tp5 r3 一个简单的SQL语句调试实例先看效果核心代码 public function index() { if (IS_AJAX && session("uid&quo ...
- Oracle数据库查找持有锁的SQL语句,而不是请求锁的SQL语句(原创)
Oracle数据库查找持有锁的SQL语句,而不是请求锁的SQL语句 查找活动的事务以及活动事务关联的会话信息 select s.sid 会话ID, s.serial# 会话序列号, s.usernam ...
随机推荐
- linux下jdk与tomcat的安装与配置
Linux中jdk与tomcat的安装与配置 1.搭建环境: (1)Linux环境:CentOS6.1 (2)jdk-1.8 (3)tomcat-9.0 2.在Linux系统上创建目录 在usr/lo ...
- JAVA使用Ldap操作AD域
项目上遇到的需要在集成 操作域用户的信息的功能,第一次接触ad域,因为不了解而且网上其他介绍不明确,比较费时,这里记录下. 说明: (1). 特别注意:Java操作查询域用户信息获取到的数据和域管理员 ...
- Table标题行冻结,数据行滚动的一种方式
这段时间在做Table标题行冻结,数据行滚动,虽然能实现,但也遇到一些问题,记录下来. 首先说说实现,实现其实不难,估计很多人都能想象出来,那就是标题行与内容行分离.我是这么做的,用两个表格,一个只有 ...
- Android 网络图片查看器与网页源码查看器
在AndroidManifest.xml里面先添加访问网络的权限: <uses-permission android:name="android.permission.INTERNET ...
- Ionic2/angularJs2中的静态类 PhotoLibrary 调用不上
photoLibrary调用报错:No provider for PhotoLibrary: 在调用相册文件时有用到photolibrary,总有些莫名的报错,3月份的时候这个坑让我不知所措,现在写下 ...
- spark web ui
spark UI 界面:http://www.cnblogs.com/xing901022/p/6445254.html 几个概念的解释:http://blog.csdn.net/jiangwlee/ ...
- python学习笔记(2)——练习小程序之 " input " 隐藏陷阱
练习小程序之 ----------" input " 隐藏陷阱 age=input('please enter your age:') if age>=18: print(' ...
- linux使用crontab实现PHP执行计划定时任务
linux使用crontab实现PHP执行计划定时任务 前几天写过一篇文章,利用单纯的php实现定时执行任务,但是效率不佳,对于linux来说用crontab实现更加合理 首先说说cron,它是一个l ...
- GPC:使用GPC计算intersection容易出现的问题
在使用GPC计算多边形的交的时候,出现问题 //1.2. 另一种方法,判断新的多边形是否和老多边形相交 Poly cross = (PolyDefault) Clip.intersection ...
- CAD控件:梦想CAD控件功能更新 清除图上的所有高亮实体
1,修正得组里面的实体,把删除实体也返回的错误 2,修正代理实体改不了颜色问题. 3,修正捕捉块插入点,有时会跑到很远的位置问题. 4.MxDrawChange类增加ToBlockRefe ...