1.1数据库的一些知识
数据库是将大量数据保存起来,通过计算机加工而成的可以进行高效访问的数据集合。该数据集合称为数据库(Database,DB)。用来管理数据库的计算机系统称为数据库管理系统(Database Management System,DBMS)。
DBMS的种类:
SQL语句的种类:
1.2数据库的创建
–如何创建数据库?
mysql> CREATE DATABASE shop;`
–如何查看是否成功地创建了数据库?
mysql> SHOW DATABASES`
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| shop |
| sys |
| test |
+--------------------+
6 rows in set (0.00 sec)
1.3数据表的创建
mysql> 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));
–查看数据表是否创建成功
mysql> SHOW TABLES;
+----------------+
| Tables_in_shop |
+----------------+
| product |
+----------------+
1 row in set (0.00 sec)
1.4命名规则
- 只能使用半角英文字母、数字、下划线(_)作为数据库、表和列的名称
- 名称必须以半角英文字母开头
1.5数据类型
- INTEGER 型
用来指定存储整数的列的数据类型(数字型),不能存储小数。
- CHAR 型
用来存储定长字符串,当列中存储的字符串长度达不到最大长度的时候,使用半角空格进行补足,由于会浪费存储空间,所以一般不使用。
- VARCHAR 型
用来存储可变长度字符串,定长字符串在字符数未达到最大长度时会用半角空格补足,但可变长字符串不同,即使字符数未达到最大长度,也不会用半角空格补足。
- DATE 型
用来指定存储日期(年月日)的列的数据类型(日期型)。
1.6约束
约束是除了数据类型之外,对列中存储的数据进行限制或者追加条件的功能。
NOT NULL
是非空约束,即该列必须输入数据。
PRIMARY KEY
是主键约束,代表该列是唯一值,可以通过该列取出特定的行的数据。
1.7表的删除和更新
–删除 product 表
mysql> DROP TABLE product;
Query OK, 0 rows affected (0.03 sec)
–添加一列可以存储100位的可变长字符串的 product_name_pinyin 列的ALTER TABLE语句
mysql> ALTER TABLE product ADD COLUMN product_name_pinyin VARCHAR(100);
Query OK, 0 rows affected (0.02 sec)
Records: 0 Duplicates: 0 Warnings: 0
–删除 product_name_pinyin 列的ALTER TABLE 语句
mysql> ALTER TABLE product DROP COLUMN product_name_pinyin;_
–清空数据表
TRUNCATE TABLE shop;
优点:相比drop / delete
,truncate
用来清除数据时,速度最快。
1.8数据表的更新
基本语法:
UPDATE <表名>
SET <列名> = <表达式> [, <列名2>=<表达式2>...];
WHERE <条件>; -- 可选,非常重要。
ORDER BY 子句; --可选
LIMIT 子句; --可选
单列更新
可以使用WHERE语句来限定修改的范围
-- 修改所有的注册时间
UPDATE product
SET regist_date = '2009-10-10';
-- 仅修改部分商品的单价
UPDATE product
SET sale_price = sale_price * 10
WHERE product_type = '厨房用具';
UPDATE语句进行NULL清空(仅针对未设置 NOT NULL 约束和主键约束的列)
-- 将商品编号为0008的数据(圆珠笔)的登记日期更新为NULL
UPDATE product
SET regist_date = NULL
WHERE product_id = '0008';
多列更新
UPDATE product
SET sale_price = sale_price * 10,
purchase_price = purchase_price / 2
WHERE product_type = '厨房用具';
1.8 向 product 表中插入数据
用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 INTO <表名> (列1, 列2, 列3, ……) VALUES (值1, 值2, 值3, ……);
进行全列INSERT时可以省略为:
INSERT INTO <表名> VALUES (值1, 值2, 值3, ……);
多行同时插入数据:
INSERT INTO <表名> VALUES (值1, 值2, 值3, ……),
(值1, 值2, 值3, ……),
(值1, 值2, 值3, ……);
可以插入NULL值:
INSERT INTO productins (product_id, product_name, product_type, sale_price, purchase_price, regist_date) VALUES ('0006', '叉子', '厨房用具', 500, NULL, '2009-09-20');
还可以向表中插入默认值(初始值):
CREATE TABLE productins
(product_id CHAR(4) NOT NULL,
(略)
sale_price INTEGER
(略) DEFAULT 0, -- 销售单价的默认值设定为0;
PRIMARY KEY (product_id));
可以使用INSERT … SELECT 语句从其他表复制数据
-- 将商品表中的数据复制到商品复制表中
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;
本课程用表插入数据sql如下:
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');
查看数据表中的数据
mysql> select * from product;
1.9索引
如何创建索引
方法一:
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)
练习题
1.1
编写一条 CREATE TABLE 语句,用来创建一个包含表 1-A 中所列各项的表 Addressbook (地址簿),并为 regist_no (注册编号)列设置主键约束
表1-A 表 Addressbook (地址簿)中的列
答案:
CREATE TABLE Addressbook
(Addressbook_regist_no INTEGER NOT NULL,
Addressbook_name VARCHAR(128) NOT NULL,
Addressbook_address VARCHAR(256) NOT NULL,
Addressbook_tel_no CHAR(10),
Addressbook_mail_address CHAR(20),
PRIMARY KEY(Addressbook_regist_no));
1.2
假设在创建练习1.1中的 Addressbook 表时忘记添加如下一列 postal_code (邮政编码)了,请编写 SQL 把此列添加到 Addressbook 表中。
列名 : postal_code
数据类型 :定长字符串类型(长度为 8)
约束 :不能为 NULL
答案:
ALTER TABLE Addressbook ADD COLUMN postal_code CHAR(8) NOT NULL;
1.3 填空题
请补充如下 SQL 语句来删除 Addressbook 表。
答案:
( drop ) table Addressbook;
1.4 判断题
是否可以编写 SQL 语句来恢复删除掉的 Addressbook 表?
此列添加到 Addressbook 表中。
列名 : postal_code
数据类型 :定长字符串类型(长度为 8)
约束 :不能为 NULL
答案:
ALTER TABLE Addressbook ADD COLUMN postal_code CHAR(8) NOT NULL;
1.3 填空题
请补充如下 SQL 语句来删除 Addressbook 表。
答案:
( drop ) table Addressbook;
1.4 判断题
是否可以编写 SQL 语句来恢复删除掉的 Addressbook 表?
答案:不行