python学习之路-day12-mysql && orm

python

一、数据库

1、数据库介绍

数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,
每个数据库都有一个或多个不同的API用于创建,访问,管理,搜索和复制所保存的数据。
我们也可以将数据存储在文件中,但是在文件中读写数据速度相对较慢。
所以,现在我们使用关系型数据库管理系统(RDBMS)来存储和管理的大数据量。所谓的关系型数据库,是建立在关系模型基础上的数据库,借助于集合代数等数学概念和方法来处理数据库中的数据。
RDBMS即关系数据库管理系统(Relational Database Management System)的特点:
1.数据以表格的形式出现
2.每行为各种记录名称
3.每列为记录名称所对应的数据域
4.许多的行和列组成一张表单
5.若干的表单组成database

2、数据库操作

  • 创建一个表

python;gutter:true;">create table student(

stu_id INT NOT NULL AUTO_INCREMENT,

name CHAR(32) NOT NULL,

age INT NOT NULL,

register_date DATE,

PRIMARY KEY ( stu_id )

)

实例解析:

  • 如果你不想字段为 NULL 可以设置字段的属性为 NOT NULL, 在操作数据库时如果输入该字段的数据为NULL ,就会报错。
  • AUTO_INCREMENT定义列为自增的属性,一般用于主键,数值会自动加1。
  • PRIMARY KEY关键字用于定义列为主键。 您可以使用多列来定义主键,列间以逗号分隔。

  • 插入数据

mysql> insert into student (name,age,register_date) values ("alex li",22,"2016-03-4")

-> ;

Query OK, 1 row affected (0.00 sec)

mysql> select * from student;

+--------+---------+-----+---------------+

| stu_id | name | age | register_date |

+--------+---------+-----+---------------+

| 1 | alex li | 22 | 2016-03-04 |

+--------+---------+-----+---------------+

1 row in set (0.00 sec)

  •  查询数据

mysql> select * from student limit 3 offset 2;

+--------+---------+-----+---------------+

| stu_id | name | age | register_date |

+--------+---------+-----+---------------+

| 3 | alex li | 24 | 2016-03-04 |

| 4 | alex li | 24 | 2016-03-01 |

| 5 | alex li | 24 | 2016-03-02 |

+--------+---------+-----+---------------+

3 rows in set (0.00 sec)

比如这个SQL ,limit后面跟的是3条数据,offset后面是从第3条开始读取

mysql> select * from student limit 3 ,1;

+--------+---------+-----+---------------+

| stu_id | name | age | register_date |

+--------+---------+-----+---------------+

| 4 | alex li | 24 | 2016-03-01 |

+--------+---------+-----+---------------+

1 row in set (0.00 sec)

而这个SQL,limit后面是从第3条开始读,读取1条信息。

  • 查询语句中你可以使用一个或者多个表,表之间使用逗号(,)分割,并使用WHERE语句来设定查询条件。
  • SELECT 命令可以读取一条或者多条记录。
  • 你可以使用星号(*)来代替其他字段,SELECT语句会返回表的所有字段数据
  • 你可以使用 WHERE 语句来包含任何条件。
  • 你可以通过OFFSET指定SELECT语句开始查询的数据偏移量。默认情况下偏移量为0。
  • 你可以使用 LIMIT 属性来设定返回的记录数。
  • where子句

语法:

SELECT field1, field2,...fieldN FROM table_name1, table_name2...

[WHERE condition1 [AND [OR]] condition2.....

例:

select * from student where register_date > '2016-03-04';

操作符

描述实例
=等号,检测两个值是否相等,如果相等返回trueA = B) 返回false。
<>, !=不等于,检测两个值是否相等,如果不相等返回true(A != B) 返回 true。
>大于号,检测左边的值是否大于右边的值, 如果左边的值大于右边的值返回true(A > B) 返回false。
<小于号,检测左边的值是否小于右边的值, 如果左边的值小于右边的值返回true(A < B) 返回 true。
>=大于等于号,检测左边的值是否大于或等于右边的值, 如果左边的值大于或等于右边的值返回true(A >= B) 返回false。
<=小于等于号,检测左边的值是否小于于或等于右边的值, 如果左边的值小于或等于右边的值返回trueA <= B) 返回 true。

以上为操作符列表,可用于 WHERE 子句中。

下表中实例假定 A为10 B为20

UPDATE 查询

UPDATE table_name SET field1=new-value1, field2=new-value2

[WHERE Clause]

update student set age=22 ,name="Alex Li" where stu_id>3;

MySQL DELETE 语句

DELETE FROM table_name [WHERE Clause]<br><br>delete from student where stu_id=5; 

MySQL LIKE 子句

SELECT field1, field2,...fieldN table_name1, table_name2...

WHERE field1 LIKE condition1 [AND [OR]] filed2 = 'somevalue'

select *from student where name binary like "%Li";

select *from student where name binary like binary "%Li"; #只匹配大写

MySQL 排序

SELECT field1, field2,...fieldN table_name1, table_name2...

ORDER BY field1, [field2...] [ASC [DESC]]

使用 ASC 或 DESC 关键字来设置查询结果是按升序或降序排列。 默认情况下,它是按升序排列。

select *from student where name like binary "%Li" order by stu_id desc;

MySQL GROUP BY 语句  

SELECT column_name, function(column_name)

FROM table_name

WHERE column_name operator value

GROUP BY column_name;

mysql> SELECT* FROMemployee_tbl;

+----+--------+---------------------+--------+

| id | name   | date                | singin |

+----+--------+---------------------+--------+

|  1 | 小明 | 2016-04-22 15:25:33 |      1 |

|  2 | 小王 | 2016-04-20 15:25:47 |      3 |

|  3 | 小丽 | 2016-04-19 15:26:02 |      2 |

|  4 | 小王 | 2016-04-07 15:26:14 |      4 |

|  5 | 小明 | 2016-04-11 15:26:40 |      4 |

|  6 | 小明 | 2016-04-04 15:26:54 |      2 |

+----+--------+---------------------+--------+

 

接下来我们使用 GROUPBY语句 将数据表按名字进行分组,并统计每个人有多少条记录:

mysql> SELECTname, COUNT(*) FROM   employee_tbl GROUPBYname;

+--------+----------+

| name   | COUNT(*) |

+--------+----------+

| 小丽 |        1 |

| 小明 |        3 |

| 小王 |        2 |

+--------+----------+

3 rowsinset(0.01 sec)

 

使用 WITHROLLUP

mysql> SELECTname, SUM(singin) assingin_count FROM  employee_tbl GROUPBYnameWITHROLLUP;

+--------+--------------+

| name   | singin_count |

+--------+--------------+

| 小丽 |            2 |

| 小明 |            7 |

| 小王 |            7 |

| NULL   |           16 |

+--------+--------------+

4 rowsinset(0.00 sec)

其中记录 NULL表示所有人的登录次数。<br>

我们可以使用 coalesce来设置一个可以取代 NUll的名称,coalesce语法:

mysql> SELECTcoalesce(name, '总数'), SUM(singin) assingin_count FROM  employee_tbl GROUPBYnameWITHROLLUP;

MySQL ALTER命令

我们需要修改数据表名或者修改数据表字段时,就需要使用到MySQL ALTER命令。

删除,添加或修改表字段

alter table student drop register_date; #从student表删除register_date   字段alter table student add phone int(11) not null; #添加phone字段

修改字段类型及名称

如果需要修改字段类型及名称, 你可以在ALTER命令中使用 MODIFY 或 CHANGE 子句 。

例如,把字段 c 的类型从 CHAR(1) 改为 CHAR(10),可以执行以下命令:

mysql> ALTER TABLE testalter_tbl MODIFY c CHAR(10);

使用 CHANGE 子句, 语法有很大的不同。 在 CHANGE 关键字之后,紧跟着的是你要修改的字段名,然后指定新字段名及类型。尝试如下实例:

mysql> ALTER TABLE testalter_tbl CHANGE i j BIGINT;

mysql> ALTER TABLE testalter_tbl CHANGE j j INT;

ALTER TABLE 对 Null 值和默认值的影响

当你修改字段时,你可以指定是否包含只或者是否设置默认值。

以下实例,指定字段 j 为 NOT NULL 且默认值为100 。

mysql> ALTER TABLE testalter_tbl

-> MODIFY j BIGINT NOT NULL DEFAULT 100;

修改表名

mysql> ALTER TABLE testalter_tbl RENAME TO alter_tbl;

关于外键

外键,一个特殊的索引,用于关键2个表,只能是指定内容

mysql> create table class(

-> id int not null primary key,

-> name char(16));

Query OK, 0 rows affected (0.02 sec)

CREATE TABLE `student2` (

`id` int(11) NOT NULL,

`name` char(16) NOT NULL,

`class_id` int(11) NOT NULL,

PRIMARY KEY (`id`),

KEY `fk_class_key` (`class_id`),

CONSTRAINT `fk_class_key` FOREIGN KEY (`class_id`) REFERENCES `class` (`id`)

)

 此时如果class 表中不存在id 1,student表也插入不了,这就叫外键约束

mysql> insert into student2(id,name,class_id) values(1,'alex', 1);

ERROR 1452 (23000): Cannot add or update a child row: a foreign key constraint fails (`testdb`.`student2`, CONSTRAINT `fk_class_key` FOREIGN KEY (`class_id`) REFERENCES `class` (`id`))

mysql> insert into class(id,name) values(1,"linux");

Query OK, 1 row affected (0.01 sec)

mysql> insert into student2(id,name,class_id) values(1,'alex', 1);

Query OK, 1 row affected (0.00 sec)

#如果有student表中跟这个class表有关联的数据,你是不能删除class表中与其关联的纪录的

mysql> delete from class where id =1;

ERROR 1451 (23000): Cannot delete or update a parent row: a foreign key constraint fails (`testdb`.`student2`, CONSTRAINT `fk_class_key` FOREIGN KEY (`class_id`) REFERENCES `class` (`id`))

http://www.cnblogs.com/alex3714/articles/5950372.html

以上是 python学习之路-day12-mysql && orm 的全部内容, 来源链接: utcz.com/z/387864.html

回到顶部