T-SQL基础教程Day1
Posted SQL Server学习
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了T-SQL基础教程Day1相关的知识,希望对你有一定的参考价值。
1.1 理论背景
SQL代表结构化查询语言(Structured Query Language),是一种在关系数据库系统(Relational Database Management Systems,RDBMS)中查询和管理数据的标准语言。
RDBMS是基于关系模型的数据库管理系统,
它基于两个数学分支:集合理论和谓词逻辑。
1.1.1 SQL
SQL是一种基于关系模型的ANSI和ISO标准语言,用于查询和管理RDBMS中的数据。
SQL语句包括
数据定义语言Data Definition Language, DDL
数据操作语言Data Manipulation Language, DML
数据控制语言Data Control Language, DCL
1.1.2 集合理论
集合,我们的意思是:任意集合体M使我们感知或想到的,能够确定的、互异对象m(称为M的元素)的整体。
——Georg Cantor
一个“集合”应将其视为单个实体。
“互异”指集合中的每个元素必须是唯一的。
“我们感知或想到的”意味着集合的定义是主观的。
“对象”集合的定义不限于物理对象,更与抽血的对象相关。
请注意,定义中没有提到集合元素间的任何顺序,集合元素的列出顺序并不重要。
1.1.3 谓词逻辑
谓词是一个属性或是一个表示“持有”或“不持有”的表达式,
换句话说,也就是“真”或“假”。
关系模型就是依靠谓词来维护数据的逻辑完整性并定义其结构的。
谓词用于实施完整性的一个例子就是:在一个名为Employees的表中定义了约束,仅允许工资(Salary)大于0的雇员存储在表中。
谓词是“工资大于0”(T-SQL表达式:salary>0)。
通过筛选数据来界定子集等操作时,也可以使用谓词。
1.1.4 关系模型
关系模型的目标是确保数据的一致性表示,最小化或是没有冗余且不牺牲完整性,并将定义数据的完整性作为模型的一部分。
1.关系
普通的想法是,“关系”术语源于表之间的关系,这是不正确的。
“关系”实际上是数学术语的关系。
在集合理论中,关系是集合的表现形式。在关系模型中,关系是相关的信息的集合,与SQL中相对应的就是表——尽管不能完全对应。
2. 缺失值
三值谓词逻辑是指来自谓词结果的3中可能逻辑值
——“真”、“假”、“未知”
3. 约束
数据完整性通过在数据模型中定义的约束规则实现,并由RDBMS实施。
4. 规范化
关系模型还定义了规范化规则,也称范式。
1NF,2NF,3NF(具体上网查阅定义)
1.1.5 数据生命周期
1 联机事务处理
OLTP系统的重点是数据输入,而不是数据报告。
2 数据仓库
DW是一个以检索数据和报告为目的设计的环境。
3 商业智能语义模型
BISM是微软支持完整BI堆栈应用的最新模型,目的是提供丰富、灵活、高效、可扩展的分析和报告功能。
4 数据挖掘
数据挖掘模型可以替代用户在数据海洋中查找有用的信息。
1.2 SQL Server体系结构
1.2.1 SQL Server的ABC特色
A是应用(Appliance)
“应用”特色背后的理念是提供包括硬件、软件和服务在内的完整解决方案,应用是在客户端本地托管的。
B是盒子(Box)
“盒子”是企业内部部署的SQL Server,这是传统的部署方式。
C是云(Cloud)
微软支持两种SQL Server云特色:私有云和公共云。
1.2.2 SQL Server实例
可以在同一台计算机上安装基于企业内部部署的SQL Server的多个实例。每个实例完全独立于其他实例。
默认实例和命名实例
1.2.3 数据库
系统数据库介绍如下:
master:存储实例范围的元数据信息、服务器配置、实例中的所有数据库信息和初始化信息。
resource:Resource数据库是一个隐藏、制度数据库,存储所有系统对象的定义。当查询数据库中的系统对象时,似乎位于当前数据库的sys架构中,但实际上他们的定义位于Resource数据库中。
model:用作创建新数据库的模板,创建的每个新数据库是有model的副本初始化创建的。
tempdb:是SQL Server存储临时数据的地方,如工作表、排序空间、行版本控制信息等。
msdb:是一个成为“SQL Server代理”的服务存储数据的地方。还存储其他SQL Server功能的相关信息,如Database Mail,Service Broker、备份等等。
1.3.1 创建表
-- Create table Employees USE TSQL2012; IF OBJECT_ID( \'dbo.Employees\' , \'U\' ) IS NOT NULL DROP TABLE dbo.Employees; CREATE TABLE dbo.Employees ( empid INT NOT NULL , firstname VARCHAR (30) NOT NULL , lastname VARCHAR (30) NOT NULL , hiredate DATE NOT NULL , mgrid INT NULL , ssn VARCHAR (20) NOT NULL , salary MONEY NOT NULL );
1.3.2 定义数据完整性
-------------------------------------------------------- -- Data Integrity -------------------------------------------------------- -- Primary key ALTER TABLE dbo.Employees ADD CONSTRAINT PK_Employees PRIMARY KEY (empid); -- Unique ALTER TABLE dbo.Employees ADD CONSTRAINT UNQ_Employees_ssn UNIQUE (ssn); -- Table used in foreign key example IF OBJECT_ID( \'dbo.Orders\' , \'U\' ) IS NOT NULL DROP TABLE dbo.Orders; CREATE TABLE dbo.Orders ( orderid INT NOT NULL , empid INT NOT NULL , custid VARCHAR (10) NOT NULL , orderts DATETIME2 NOT NULL , qty INT NOT NULL , CONSTRAINT PK_Orders PRIMARY KEY (orderid) ); -- Foreign keys ALTER TABLE dbo.Orders ADD CONSTRAINT FK_Orders_Employees FOREIGN KEY (empid) REFERENCES dbo.Employees(empid); ALTER TABLE dbo.Employees ADD CONSTRAINT FK_Employees_Employees FOREIGN KEY (mgrid) REFERENCES dbo.Employees(empid); -- Check ALTER TABLE dbo.Employees ADD CONSTRAINT CHK_Employees_salary CHECK (salary > 0.00); -- Default ALTER TABLE dbo.Orders ADD CONSTRAINT DFT_Orders_orderts DEFAULT (SYSDATETIME()) FOR orderts;
附第一章配套代码:
--------------------------------------------------------------------- -- Microsoft SQL Server T-SQL Fundamentals -- Chapter 1 - Background to T-SQL Querying and Programming --2008 Itzik Ben-Gan --------------------------------------------------------------------- --------------------------------------------------------------------- -- Creating Tables --------------------------------------------------------------------- -- Create a database called testdb IF DB_ID(\'testdb\') IS NULL CREATE DATABASE testdb; GO -- Create table Employees USE testdb; IF OBJECT_ID(\'dbo.Employees\', \'U\') IS NOT NULL DROP TABLE dbo.Employees; CREATE TABLE dbo.Employees ( empid INT NOT NULL, firstname VARCHAR(30) NOT NULL, lastname VARCHAR(30) NOT NULL, hiredate DATE NOT NULL, mgrid INT NULL, ssn VARCHAR(20) NOT NULL, salary MONEY NOT NULL ); --------------------------------------------------------------------- -- Data Integrity --------------------------------------------------------------------- -- Primary key ALTER TABLE dbo.Employees ADD CONSTRAINT PK_Employees PRIMARY KEY(empid); -- Unique ALTER TABLE dbo.Employees ADD CONSTRAINT UNQ_Employees_ssn UNIQUE(ssn); -- Foreign key IF OBJECT_ID(\'dbo.Orders\', \'U\') IS NOT NULL DROP TABLE dbo.Orders; CREATE TABLE dbo.Orders ( orderid INT NOT NULL, empid INT NOT NULL, custid VARCHAR(10) NOT NULL, orderts DATETIME NOT NULL, qty INT NOT NULL, CONSTRAINT PK_Orders PRIMARY KEY(OrderID) ); ALTER TABLE dbo.Orders ADD CONSTRAINT FK_Orders_Employees FOREIGN KEY(empid) REFERENCES dbo.Employees(empid); ALTER TABLE dbo.Employees ADD CONSTRAINT FK_Employees_Employees FOREIGN KEY(mgrid) REFERENCES Employees(empid); -- Check ALTER TABLE dbo.Employees ADD CONSTRAINT CHK_Employees_salary CHECK(salary > 0); -- Default ALTER TABLE dbo.Orders ADD CONSTRAINT DFT_Orders_orderts DEFAULT(CURRENT_TIMESTAMP) FOR orderts;
JAVA入门零基础小白教程day06-类和对象
4day06-JAVAOOP
课程目标
1. 【理解】 什么是面向对象
2. 【理解】 类和对象的关系
3. 【掌握】 类的定义和使用
4. 【掌握】 三大特征之封装
5. 【掌握】 this关键字的使用
一.面向对象概述
1.1什么是面向对象
Java语言是一种面向对象的程序设计语言,而面向对象思想是一种程序设计思想,我们在面向对象思想的指引下, 使用Java语言去设计、开发计算机程序。 这里的对象泛指现实中一切事物,每种事物都具备自己的属性和行为。面向对象思想就是在计算机程序设计过程中,参照现实中事物,将事物的属性特征、行为特征抽象出来,描述成计算 机事件的设计思想。 它区别于面向过程思想,强调的是通过调用对象的行为来实现功能,而不是自己一步一步的去操作实现。
1.2面向过程与面向对象
面向过程
完成一个功能时,功能的每一个步骤,都需要我们进行参与,每一个细节都需要了解清楚,才能完成。强调的是过程。
面向对象
强调的是通过调用对象的行为来实现功能,而不是自己一步一步的去 操作实现
举例
1.3三大特征
封装 继承 多态
层层递进 互为前提
1.4小结
做事情 首先第一想到的是对象,那个对象能帮我们做事情
有对象: 直接用
没有对象: 我们自己造对象在进行使用
二.类和对象
2.1什么是类
类是一组相关属性和行为的集合。类就是现实生活的一个事物(java语言就是对于现实生活的描述),事物由属性和行为组成。
【类就是描述现实生活中的某一个事物,这个事物是由属性和行为组成】
2.2什么是对象
对象:是一类事物的具体体现。对象是类的一个实例(对象并不是找个女朋友),必然具备该类事物的属性和行为
2.3类与对象的关系
类是对一类事物的描述,是抽象的
对象是一类事物的实例,是具体的
类是对象的模板,对象是类的实体
类:学生 汽车图纸
对象: 班长,一个具体的对象 大众 宝马 MG
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Do8TXHaX-1671636998999)(assets/类与对象的关系.png)]
三.类的定义和使用
3.1类的定义
3.1.1语法格式
public class 类名
//成员变量 --属性
//成员方法 --行为
3.1.2定义学生类
public class Student //成员变量
String name;//姓名
int age;//年龄
// 成员方法
// 学习的方法
public void study()
System.out.println("好好学习,天天向上");
//吃饭的方法
public void eat()
System.out.println("学习饿了要吃饭");
3.2对象的使用
3.2.1创建对象格式
类名 对象名 = new 类名();
3.2.2访问类中的成员
对象名.成员变量;
对象名.成员方法();
代码演示
public class Test01_Student
public static void main(String[] args)
//创建对象格式:类名 对象名 = new 类名();
Student s = new Student();
System.out.println("s:"+s); //
//直接输出成员变量值
System.out.println("姓名:"+s.name); //null
System.out.println("年龄:"+s.age); //0
System.out.println("‐‐‐‐‐‐‐‐‐‐");
//给成员变量赋值
s.name = "赵丽颖";
s.age = 18;
//再次输出成员变量的值
System.out.println("姓名:"+s.name); //赵丽颖
System.out.println("年龄:"+s.age); //18
System.out.println("‐‐‐‐‐‐‐‐‐‐");
//调用成员方法
s.study(); // "好好学习,天天向上"
s.eat(); // "学习饿了要吃饭"
3.3成员变量的默认值
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-EOp8yppV-1671636999002)(assets/image-20201104232954593.png)]
3.4类与对象的练习
-
定义手机类
public class Phone // 成员变量 String brand; //品牌 int price; //价格 String color; //颜色 // 成员方法 //打电话 public void call(String name) System.out.println("给"+name+"打电话"); //发短信 public void sendMessage() System.out.println("群发短信");
-
测试类
public class Test02Phone public static void main(String[] args) //创建对象 Phone p = new Phone(); //输出成员变量值 System.out.println("品牌:"+p.brand);//null System.out.println("价格:"+p.price);//0 System.out.println("颜色:"+p.color);//null System.out.println("‐‐‐‐‐‐‐‐‐‐‐‐"); //给成员变量赋值 p.brand = "锤子"; p.price = 2999; p.color = "棕色"; //再次输出成员变量值 System.out.println("品牌:"+p.brand);//锤子 System.out.println("价格:"+p.price);//2999 System.out.println("颜色:"+p.color); //棕色 System.out.println("‐‐‐‐‐‐‐‐‐‐‐‐"); //调用成员方法 p.call("紫霞"); p.sendMessage();
四.成员变量和局部变量的区别
五.封装
5.1什么是封装
面向对象编程语言是对客观世界的模拟,客观世界里成员变量都是隐藏在对象内部的,外界无法直接操作和修改。 封装可以被认为是一个保护屏障,防止该类的代码和数据被其他类随意访问。要访问该类的数据,必须通过指定的方式。适当的封装可以让代码更容易理解与维护,也加强了代码的安全性。
5.2封装的引入
/*
定义一个学生类:
成员变量:name,age
成员方法:show()方法
private:私有的。可以修饰成员变量和成员方法。
注意:被private修饰的成员只能在本类中访问。
其实我讲到现在讲解的是一个封装的思想。
封装:是指隐藏对象的属性和实现细节,仅对外提供公共访问方式。
*/
public class Student
//姓名
String name;
//年龄
private int age;
/**
* 为了年龄的正确性,写一个方法给年龄进行赋值
* 两个明确: 1、需要一个int类型的参数
* 2、需要不需要返回值类型
* @param a
*/
public void setAge(int a)
if( a <=0 || a >= 100)
System.out.println("您给出的年龄有问题!!");
else
age = a;
public void show()
System.out.println("姓名:"+name);
System.out.println("年龄:"+age);
public class StudentDemo
public static void main(String[] args)
//创建对象
Student s = new Student();
s.show();
System.out.println("=========================");
//给成员变量赋值
s.name = "小江";
// s.age = 27;
s.show();
System.out.println("=========================");
s.name = "小燕";
//这次给成员变量赋值一个 负数
// s.age = -27;
//年龄给一个负数不合理,那如何是好呢?
//解决办法:不让用户直接赋值(private),然后方法(setAge())进行判断
s.setAge(27);
s.show();
5.3封装的原则
将属性隐藏起来,若需要访问某个属性,提供公共方法对其访问。
5.3.1如何封装
5.3.2private 关键字
-
什么是private关键字
1. private是一个权限修饰符,代表最小权限。 2. 可以修饰成员变量和成员方法。 3. 被private修饰后的成员变量和成员方法,只在本类中才能访问
-
private的使用格式
private 数据类型 变量名 ;
-
使用 private 修饰成员变量,代码如下
public class Student //private修饰成员变量 private int num = 10; public void show() //private 只能在本类中使用 System.out.println(num); //private修饰成员 private void method() System.out.println("我是method"); public void function() //private 只能在本类中使用 method();
public class StudentTest
public static void main(String[] args)
Student s = new Student();
//不能访问私有的成员变量
// System.out.println(s.num);
s.show();
//不能访问私有的成员方法
// s.method();
s.function();
-
提供
getXxx
方法 /setXxx
方法,可以访问成员变量,代码如下public class Student //姓名 private String name; //年龄 private int age; //姓名获取值 public String getName() return name; //姓名设置值 public void setName(String n) name = n; //年龄获取值 public int getAge() return age; //年龄设置值 public void setAge(int a) age = a;
public class StudentDemo
public static void main(String[] args)
//创建对象
Student s = new Student();
//使用成员变量
//错误: 私有的成员变量是不能被访问的
// System.out.println(s.name);
// System.out.println(s.age);
//通过方法访问成员变量
System.out.println(s.getName()+" : "+s.getAge());
//给成员变量赋值
s.setName("一燕");
s.setAge(18);
System.out.println(s.getName()+" : "+s.getAge());
5.3.3 this 关键字
-
问题描述
我们发现 setXxx 方法中的形参名字并不符合见名知意的规定,那么如果修改与成员变量名一致,是否就见名知意 了呢?代码如下:
public class Student private String name; private int age; public void setName(String name) name = name; public void setAge(int age) age = age;
经过修改和测试,我们发现新的问题,成员变量赋值失败了。也就是说,在修改了 setXxx() 的形参变量名后,方法并没有给成员变量赋值!这是由于形参变量名与成员变量名重名,导致成员变量名被隐藏,方法中的变量名,无 法访问到成员变量,从而赋值失败。所以,我们只能使用this关键字,来解决这个重名问题。
-
this
的含义this代表所在类的当前对象的引用(地址值),即对象自己的引用。
-
this
的使用格式this.成员变量名;
-
代码修改
public class Student private String name; private int age; public void setName(String name) //name = name; this.name = name; public String getName() return name;//其实这里隐含this public void setAge(int age) //age = age; this.age = age; public int getAge() return age;
六.构造方法
6.1构造方法概述
构造方法: 用于对象数据初始化
小贴士:无论你与否自定义构造方法,所有的类都有构造方法,因为Java自动提供了一个无参数构造方法,
一旦自己定义了构造方法,Java自动提供的默认无参数构造方法就会失效。
6.2构造方法的定义格式
/*
构造方法名与类名相同
没有返回值类型,连void
没有具体的返回值
*/
修饰符 构造方法名(参数列表)
// 方法体
6.3构造方法的使用
构造方法的写法上,方法名与它所在的类名相同。它没有返回值,所以不需要返回值类型,甚至不需要void。使用
构造方法后,代码如下
public class Student
private String name;
private int age;
// 无参数构造方法
public Student()
System.out.println("我是无参构造方法");
// 有参数构造方法
public Student(String name,int age)
this.name = name;
this.age = age;
public class StudentDemo
public static void main(String[] args)
//无参构造
Student s = new Student();
System.out.println(s);
//有参构造
Student s1 = new Student("小燕",27);
System.out.println(s1.getName());
System.out.println(s1.getAge());
6.3构造方法重载
// 构造方法是可以重载的
public class Student
public Student()
public Student(String name, int age)
this.name = name;
this.age = age;
public Student(String name)
this.name = name;
public Student(int age)
this.age = age;
6.4构造方法的注意事项
1. 如果你不提供构造方法,系统会给出无参数构造方法。√
2. 如果你提供了构造方法,系统将不再提供无参数构造方法。
3. 构造方法是可以重载的,既可以定义参数,也可以不定义参数。
需求: 现在类是可以创建对象,但是有些情况下不让别人创建对象,请问怎么办?
构造方法私有
标准JavaBean编写
JavaBean 是 Java语言编写类的一种标准规范。
符合 JavaBean 的类,有构造方法 , 提供操作属性的set get方法
public class ClassName
//成员变量
//构造方法
//无参构造方法【必须】
//有参构造方法【建议】
//成员方法
//getXxx()
//setXxx()
编写Student类
public class Student
//成员变量
private String name;
private int age;
//构造方法
public Student()
public Student(String name,int age)
this.name = name;
this.age = age;
//成员方法
publicvoid setName(String name)
this.name = name;
public String getName()
return name;
publicvoid setAge(int age)
this.age = age;
publicint getAge()
return age;
测试
public class TestStudent
public static void main(String[] args)
//无参构造使用
Student s= new Student();
s.setName("柳岩");
s.setAge(18);
System.out.printlnT-SQL基础教程Day3