1. 初识数据库

本文详细介绍了SQL的基础知识,包括书写规则、数据库和表的创建、命名规范、数据类型、约束、表的删除和更新操作、插入数据、索引的使用以及事务管理。重点展示了DML操作和如何提高查询性能。
摘要由CSDN通过智能技术生成

1. 书写规则

  1. SQL语句要以分号( ; )结尾
  2. SQL 不区分关键字的大小写,但是插入到表中的数据是区分大小写的
  3. win 系统默认不区分表名及字段名的大小写;linux / mac 默认严格区分表名及字段名的大小写
  4. 常数的书写方式是固定的:‘abc’, 1234, ‘26 Jan 2010’, ‘10/01/26’, ‘2010-01-26’…
  5. 单词需要用半角空格或者换行来分隔:不能使用全角空格作为单词的分隔符,否则会发生错误,出现无法预期的结果
  6. 1行注释:"-- "
  7. 多行注释:“/* */”

2. 数据库的创建

CREATE DATABASE < 数据库名称 > ;

CREATE DATABASE shop;

3. 表的创建

CREATE TABLE < 表名 >
( < 列名 1> < 数据类型 > < 该列所需约束 > ,
  < 列名 2> < 数据类型 > < 该列所需约束 > ,
  < 列名 3> < 数据类型 > < 该列所需约束 > ,
  < 列名 4> < 数据类型 > < 该列所需约束 > ,
  .
  .
  .
  < 该表的约束 1> , < 该表的约束 2> ,……);

CREATE TABLE product
(product_id CHAR(4) NOT NULL,
 product_name VARCHAR(100) NOT NULL,
 product_type VARCHAR(32) NOT NULL,
 sale_price INTEGER ,
 purchase_price INTEGER ,
 regist_date DATE ,
 PRIMARY KEY (product_id));

4. 命名规则

  1. 只能使用半角英文字母、数字、下划线(_)作为数据库、表和列的名称
  2. 名称必须以半角英文字母开头

5. 数据类型

  1. INTEGER:整数
  2. CHAR 型:长字符串
    当列中存储的字符串长度达不到最大长度的时候,使用半角空格进行补足,由于会浪费存储空间,所以一般不使用。
  3. VARCHAR:可变长度字符串
    即使字符数未达到最大长度,也不会用半角空格补足。
  4. DATE 型:日期(年月日)

6. 约束

  1. NOT NULL:非空约束
    该列必须输入数据。
  2. PRIMARY KEY:主键约束
    该列是唯一值,可以通过该列取出特定的行的数据。

7. 表的删除和更新

  • 删除表
    删除的表是无法恢复的,只能重新插入
DROP TABLE < 表名 > ;
DROP TABLE product;
  • 添加列
    ALTER TABLE 语句和 DROP TABLE 语句一样,执行之后无法恢复
ALTER TABLE < 表名 > ADD COLUMN < 列的定义 >;

ALTER TABLE product ADD COLUMN product_name_pinyin VARCHAR(100);
  • 删除列
ALTER TABLE < 表名 > DROP COLUMN < 列名 >;

ALTER TABLE product DROP COLUMN product_name_pinyin;
  • 删除表中特定的行
    一定注意添加 WHERE 条件,否则将会删除所有的数据
DELETE FROM product WHERE COLUMN_NAME='XXX';
  • 清空表内容
    相比drop / delete,truncate用来清除数据时,速度最快。
TRUNCATE TABLE TABLE_NAME;
  • 数据的更新
    使用 update 时要注意添加 where 条件,否则将会将所有的行按照语句修改
UPDATE <表名>
   SET <列名> = <表达式> [, <列名2>=<表达式2>...]  
 WHERE <条件>  -- 可选,非常重要
 ORDER BY 子句  --可选
 LIMIT 子句; --可选
 
-- 修改所有的注册时间
UPDATE product
   SET regist_date = '2009-10-10';  
   
-- 仅修改部分商品的单价
UPDATE product
   SET sale_price = sale_price * 10
 WHERE product_type = '厨房用具';  

-- 将商品编号为0008的数据(圆珠笔)的登记日期更新为NULL 
-- 和 INSERT 语句一样, UPDATE 语句也可以将 NULL 作为一个值来使用 
UPDATE product
   SET regist_date = NULL
 WHERE product_id = '0008';  
  • 多列更新
-- 基础写法,一条UPDATE语句只更新一列
UPDATE product
   SET sale_price = sale_price * 10
 WHERE product_type = '厨房用具';
UPDATE product
   SET purchase_price = purchase_price / 2
 WHERE product_type = '厨房用具';  

-- 合并后的写法
UPDATE product
   SET sale_price = sale_price * 10,
       purchase_price = purchase_price / 2
 WHERE product_type = '厨房用具';  

8. 插入数据

INSERT INTO <表名> (1,2,3, ……) VALUES (1,2,3, ……);  

-- 为了学习 INSERT 语句用法,我们首先创建一个名为 productins 的表
CREATE TABLE productins
(product_id    CHAR(4)      NOT NULL,
product_name   VARCHAR(100) NOT NULL,
product_type   VARCHAR(32)  NOT NULL,
sale_price     INTEGER      DEFAULT 0,
purchase_price INTEGER ,
regist_date    DATE ,
PRIMARY KEY (product_id)); 

-- 对表进行全列 INSERT 时,可以省略表名后的列清单。这时 VALUES子句的值会默认按照从左到右的顺序赋给每一列。
-- 包含列清单
INSERT INTO productins (product_id, product_name, product_type, sale_price, purchase_price, regist_date) VALUES ('0005', '高压锅', '厨房用具', 6800, 5000, '2009-01-15');
-- 省略列清单
INSERT INTO productins VALUES ('0005', '高压锅', '厨房用具', 6800, 5000, '2009-01-15');  
  • 插入多行
-- 通常的INSERT
INSERT INTO productins VALUES ('0002', '打孔器', '办公用品', 500, 320, '2009-09-11');
INSERT INTO productins VALUES ('0003', '运动T恤', '衣服', 4000, 2800, NULL);
INSERT INTO productins VALUES ('0004', '菜刀', '厨房用具', 3000, 2800, '2009-09-20');

-- 多行INSERT ( DB2、SQL、SQL Server、 PostgreSQL 和 MySQL多行插入)
INSERT INTO productins VALUES ('0002', '打孔器', '办公用品', 500, 320, '2009-09-11'),
                              ('0003', '运动T恤', '衣服', 4000, 2800, NULL),
                              ('0004', '菜刀', '厨房用具', 3000, 2800, '2009-09-20');  
                              
-- 多行INSERT(Oracle多行插入)
INSERT ALL INTO productins VALUES ('0002', '打孔器', '办公用品', 500, 320, '2009-09-11')
           INTO productins VALUES ('0003', '运动T恤', '衣服', 4000, 2800, NULL)
           INTO productins VALUES ('0004', '菜刀', '厨房用具', 3000, 2800, '2009-09-20')
SELECT * FROM DUAL;  
-- DUAL是Oracle特有(安装时的必选项)的一种临时表A。因此“SELECT *FROM DUAL” 部分也只是临时性的,并没有实际意义。  
  • 插入空值
INSERT INTO productins (product_id, product_name, product_type, sale_price, purchase_price, regist_date) VALUES ('0006', '叉子', '厨房用具', 500, NULL, '2009-09-20');  
  • 插入默认值(初始值)
    通过在创建表的CREATE TABLE 语句中设置DEFAULT约束来设定默认值。
CREATE TABLE productins
(product_id CHAR(4) NOT NULL,
(略)
sale_price INTEGER
(略)	DEFAULT 0, -- 销售单价的默认值设定为0;
PRIMARY KEY (product_id));  
  • 从其他表复制数据
-- 将商品表中的数据复制到商品复制表中
INSERT INTO productcopy (product_id, product_name, product_type, sale_price, purchase_price, regist_date)
SELECT product_id, product_name, product_type, sale_price, purchase_price, regist_date
  FROM Product;  
- DML :插入数据
STARTTRANSACTION;
INSERT INTO product VALUES('0001', 'T恤衫', '衣服', 1000, 500, '2009-09-20');
INSERT INTO product VALUES('0002', '打孔器', '办公用品', 500, 320, '2009-09-11');
INSERT INTO product VALUES('0003', '运动T恤', '衣服', 4000, 2800, NULL);
INSERT INTO product VALUES('0004', '菜刀', '厨房用具', 3000, 2800, '2009-09-20');
INSERT INTO product VALUES('0005', '高压锅', '厨房用具', 6800, 5000, '2009-01-15');
INSERT INTO product VALUES('0006', '叉子', '厨房用具', 500, NULL, '2009-09-20');
INSERT INTO product VALUES('0007', '擦菜板', '厨房用具', 880, 790, '2008-04-28');
INSERT INTO product VALUES('0008', '圆珠笔', '办公用品', 100, NULL, '2009-11-11');
COMMIT;
  • 作为transaction插入
    在 SQL 中,START TRANSACTIONCOMMIT 是用于管理事务(transaction)的命令。

    1. START TRANSACTION:这个命令用于开始一个新的事务。事务是一系列数据库操作的逻辑单元,要么全部成功执行,要么全部失败回滚。开始一个事务后,数据库会记录所有后续的操作,直到提交或回滚事务。

    2. COMMIT:这个命令用于提交一个事务,即确认所有在该事务中的数据库操作。一旦提交了事务,所有操作将会永久性地应用到数据库中。

    使用这两个命令可以确保数据库操作的一致性和完整性。如果在事务执行过程中发生了错误,可以使用 ROLLBACK 命令回滚事务,使数据库恢复到事务开始之前的状态。

- DML :插入数据
STARTTRANSACTION;
INSERT INTO product VALUES('0001', 'T恤衫', '衣服', 1000, 500, '2009-09-20');
INSERT INTO product VALUES('0002', '打孔器', '办公用品', 500, 320, '2009-09-11');
INSERT INTO product VALUES('0003', '运动T恤', '衣服', 4000, 2800, NULL);
INSERT INTO product VALUES('0004', '菜刀', '厨房用具', 3000, 2800, '2009-09-20');
INSERT INTO product VALUES('0005', '高压锅', '厨房用具', 6800, 5000, '2009-01-15');
INSERT INTO product VALUES('0006', '叉子', '厨房用具', 500, NULL, '2009-09-20');
INSERT INTO product VALUES('0007', '擦菜板', '厨房用具', 880, 790, '2008-04-28');
INSERT INTO product VALUES('0008', '圆珠笔', '办公用品', 100, NULL, '2009-11-11');
COMMIT;

9. 索引

索引可以大大提高MySQL的检索速度

  • 创建表时可以直接创建索引
CREATE TABLE mytable(  
 
ID INT NOT NULL,   
 
username VARCHAR(16) NOT NULL,  
 
INDEX [indexName] (username(length))  
 
);  
  • 创建索引
-- 方法1
CREATE INDEX indexName ON table_name (column_name)

-- 方法2
ALTER table tableName ADD INDEX indexName(columnName)
  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值