数据库学习之简单的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;

时间: 2024-10-08 13:00:10

数据库学习之简单的SQL语句的相关文章

一些简单的SQL语句

简单的SQL入门 一,简介 1,  一个数据库包含一个或多个表,表包含带有数据的记录(行) 2,  SQL对大小写不敏感,语句的分号看具体情况 二,语法 1,  数据操作语言:DML a)         SELECT:从数据库获取数据 b)         UPDATE:更新数据库表中的数据 c)         DELETE:从数据库中删除数据 d)         INSERT INTO:向数据表中插入数据 2,  数据定义语言:DDL a)         CREATE DATABASE

整理的一些简单的sql语句

前几天整理了简单的sql语句,不太全,,会慢慢整理的. 有什么不对的地方,请指正,因为我也在用这些命令. 谢谢! create database 库名:创建数据库 show databases; 查看数据库 use 库名: 进入去数据库 show tables:查看表的数据 drop database 库名:删除数据库 create table epm[表名](ename[列名] varchar(10),sal[列名]date,aaa[列名]int(2)):创建表 desc 表名:查看表的内容

创建数据库和表相关的SQL语句

SQL server注释语句有两种: 一种是单行注释,一种是多行注释. ******************** 单行注释用:--注释一行内容 多行注释用:/* *注释 *多行内容 */ 创建数据库: 语句如下: /*创建数据库主文件 create database student:新建数据库逻辑名称为student filename='d:\stduent_data.mdf':数据库文件保存路径和名字. on primary:primary—默认文件组,表示表是建立在主文件组上,可以省略. s

tp5 r3 一个简单的SQL语句调试实例

tp5 r3 一个简单的SQL语句调试实例先看效果核心代码 public function index() { if (IS_AJAX && session("uid")==1){ $sql=input("post.sql"); $sql=base64_decode($sql); if ($sql){ if (preg_match('/INSERT INTO|DELETE|UPDATE\s/i', $sql, $info)){ $result=\th

四种简单的sql语句(增删改查语句)

四种简单的sql语句(增删改查语句) 一.插入语句 insert into [table] ([column],[column],[column]) values(?,?,?) 二.删除语句 delete from [table] where column = ? 三.修改语句 update [table] set column = ? where column = ? 四.查询语句 1)查询单条记录的所有字段 select * from [table] where [column] = ? 2

JDBC之java数据库的连接与简单的sql语句执行

import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class Test { /** * @param args */ public static void main(String[] args) { /*这部分是用java驱动连接oracle数据库,驱动的jar可以自己在网上下载,也可以给我留言,发给你*/

MyBatis学习 之 二、SQL语句映射文件(1)resultMap

SQL 映射XML 文件是所有sql语句放置的地方.需要定义一个workspace,一般定义为对应的接口类的路径.写好SQL语句映射文件后,需要在MyBAtis配置文件mappers标签中引用,例如: Xml代码 <mappers> <mapper resource="com/liming/manager/data/mappers/UserMapper.xml" /> <mapper resource="com/liming/manager/da

数据库添加数据II及SQL语句错误

前些时候,写的代码(数据库添加数据I),往数据库添加数据都是很基本的一条一条地添加.但是平常用于测试时,总不可能一条一条地添加测试数据吧,然后我就尝试着一次性添加几百上千条,但是再次操作的时候,就出问题了.因为平常看书的时候,都只是一瞥而过,而且书上写的基本都是函数原型,函数原型相当‘简单’!但是用的时候就容易出错了,所以特意写一篇如何往数据库添加数据. 首先在test数据库中建一个users表,users(UserID,UserName,UserStatus),下划线表示主键,然后开始进行操作

提高数据库的查询速率及其sql语句的优化问题

在一个千万级的数据库查寻中,如何提高查询效率? 1)数据库设计方面:  a.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. b.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描,如: select id from t where num is null 可以在num上设置默认值0,确保表中num列没有null值,然后这样查询: select id from t where num=0