当前位置: 首页 > news >正文

一文读懂java变量类型

前言

在学习和使用Java编程语言时,理解变量类型是至关重要的基础知识。Java是一种静态类型语言,强调变量必须先声明其类型,才能进行后续操作。因此,对于初学者来说,了解Java中不同的变量类型及其特性是迈向编程成功的第一步。

本文旨在帮助大家快速、简洁地了解Java的变量类型,从而提升对编程语言的理解和应用能力。无论您是初学者还是有一定经验的开发者,我相信这篇文章将对您有所帮助。

在接下来的内容中,我将全面涵盖Java中的基本数据类型、引用数据类型以及如何声明和使用不同类型的变量。通过清晰的说明、实例代码和有趣的示意图,我将简化复杂的概念,使小伙伴们能够轻松掌握并运用Java的各种变量类型。

有哪些变量类型?

按照访问权限划分:

  • 局部变量:只在其所在的范围内有效
    1. 方法中的局部变量
  public void exampleMethod() {int num = 10; // 在方法内部声明并初始化局部变量numSystem.out.println(num); // 输出结果为10}
  1. 构造函数中的局部变量
 public class ExampleClass {public ExampleClass() {int num = 20; // 在构造函数内部声明并初始化局部变量numSystem.out.println(num); // 输出结果为20}}
  1. 代码块中的局部变量
 public void exampleMethod() {{int num = 30; // 在代码块内部声明并初始化局部变量numSystem.out.println(num); // 输出结果为30}}
  1. for循环中的局部变量
 public void exampleMethod() {for (int i = 0; i < 5; i++) {int num = i; // 在for循环内部声明并初始化局部变量numSystem.out.println(num); // 输出结果依次为0, 1, 2, 3, 4}}
  • 类变量:用关键字 static 在类中定义的变量,被所有对象共享,也称为静态变量
    1. 类方法中的类变量
 public class ExampleClass {private static int count; // 在类中声明类变量countpublic static void incrementCount() {count++; // 在类方法中使用类变量count}public static void main(String[] args) {incrementCount(); // 调用类方法修改类变量countSystem.out.println(count); // 输出结果为1}}
  1. 构造函数中的类变量
 public class ExampleClass {private static int count; // 在类中声明类变量countpublic ExampleClass() {count++; // 在构造函数中使用类变量count}public static void main(String[] args) {ExampleClass obj1 = new ExampleClass(); // 创建对象实例,调用构造函数ExampleClass obj2 = new ExampleClass(); // 创建另一个对象实例,调用构造函数System.out.println(count); // 输出结果为2,因为两次构造函数调用都修改了类变量count}}
  • 实例变量: 在类中定义的变量,每个对象都有自己的一份
    1. 在实例方法中使用实例变量
  public class ExampleClass {private int count; // 在类中声明实例变量countpublic void incrementCount() {count++; // 在实例方法中使用实例变量count}public static void main(String[] args) {ExampleClass obj = new ExampleClass(); // 创建对象实例obj.incrementCount(); // 调用实例方法修改实例变量countSystem.out.println(obj.count); // 输出结果为1,访问对象实例的实例变量count}}
  1. 构造函数中的实例变量
 public class ExampleClass {private int count; // 在类中声明实例变量countpublic ExampleClass() {count = 10; // 在构造函数中初始化实例变量count}public static void main(String[] args) {ExampleClass obj = new ExampleClass(); // 创建对象实例System.out.println(obj.count); // 输出结果为10,访问对象实例的实例变量count}}
  • 被 final 关键字 修饰的变量: 当一个变量被 final 修饰时,它表示该变量是一个常量,一旦赋值后就不能再改变 ,因此final 修饰符可以用于实例变量、局部变量和方法参数,但无法用于类(因为类无法被继承)。
    1. final实例变量
 public class ExampleClass {private final int count; // 声明一个 final 实例变量public ExampleClass() {count = 10; // 在构造函数中为 final 实例变量赋值}public static void main(String[] args) {ExampleClass obj = new ExampleClass(); // 创建对象实例// obj.count = 20; // 错误!无法修改 final 实例变量的值System.out.println(obj.count); // 输出结果为10}}
  1. final 局部变量
 public class ExampleClass {public static void main(String[] args) {final int number = 5; // 声明一个 final 局部变量// number = 10; // 错误!无法修改 final 局部变量的值System.out.println(number); // 输出结果为5}}

常规分类

  • 基本数据类型
    • 整数类型:byte、short、int、long
    • 浮点数类型:float、double
    • 字符类型:char
    • 布尔类型:boolean
  • 引用数据类型
    • 类:使用关键字 class 定义的自定义类型。
    • 接口:使用关键字 interface 定义的接口类型。
    • 数组:使用关键字 [] 创建的一组具有相同类型的数据元素。
  • 特殊类型
    • null 类型:表示变量不引用任何对象。
    • void 类型:表示方法没有返回值。

如何声明和使用

整数类型:

javaCopy Codebyte byteVariable = 127;
short shortVariable = 32767;
int intVariable = 2147483647;
long longVariable = 9223372036854775807L; // 注意:long类型的值后面需要加上"L"表示长整型System.out.println(byteVariable);
System.out.println(shortVariable);
System.out.println(intVariable);
System.out.println(longVariable);

浮点数类型:

javaCopy Codefloat floatVariable = 3.14f; // 注意:float类型的值后面需要加上"f"表示单精度浮点数
double doubleVariable = 3.1415926535;System.out.println(floatVariable);
System.out.println(doubleVariable);

字符类型:

javaCopy Codechar charVariable = 'A';
String stringVariable = "Hello";System.out.println(charVariable);
System.out.println(stringVariable);

布尔类型:

javaCopy Codeboolean booleanVariable = true;System.out.println(booleanVariable);

引用数据类型(类、接口、数组):

javaCopy Codeclass MyClass {// 类定义
}interface MyInterface {// 接口定义
}int[] intArray = {1, 2, 3, 4, 5}; // 创建一个整数类型的数组MyClass myObject = new MyClass(); // 创建一个类的实例MyInterface myInterface = new MyInterface() {// 匿名内部类实现接口
};

特殊类型:

javaCopy CodeObject nullObject = null; // null类型void myVoidMethod() {// void类型方法,无返回值
}

初始化位置、作用范围

+---------------+-------------+-------------------+-----------------+
|   变量类型     | 初始化位置   |      作用范围      |    变量类型      |
+---------------+-------------+-------------------+-----------------+
|  局部变量      | 方法、构造   |   声明所在的方法    | 基本类型或引用   |
|               | 函数或代码   |   或代码块中可见    | 类型            |
|               | 块          |                   |                 |
+---------------+-------------+-------------------+-----------------+
|  类变量        | 类中声明     | 所有方法、构造函数  | 基本类型或引用   |
|               |             | 和代码块都可访问    | 类型            |
|               |             |                   |                 |
+---------------+-------------+-------------------+-----------------+
|  final 变量   | 声明或构造    | 与上下文相关       | 基本类型或引用    |
|               | 函数中初始化  |                  | 类型             |
+---------------+-------------+-------------------+-----------------+
|  实例变量      | 类中声明     | 对象实例可访问      | 基本类型或引用   |
|               |             |                   | 类型            |
+---------------+-------------+-------------------+-----------------+

他们的相同点和不同点

相同点

  1. 声明位置:

    • 局部变量、类变量、final 修饰的变量和实例变量都是在类的内部进行声明。
    • 它们都需要指定变量的类型和名称。
  2. 访问修饰符:

    • 局部变量、类变量、final 修饰的变量和实例变量都可以使用访问修饰符来限制对其的访问(例如,public、private、protected)。
  3. 变量类型:局部变量、类变量、final 修饰的变量和实例变量可以是任何基本类型或引用类型。

    不同点

    1. 初始化位置:
      • 局部变量:在方法、构造函数或代码块中声明,并且在使用前进行初始化。
      • 类变量:在类中声明,可以在声明时初始化或在静态代码块中初始化。
      • final 修饰的变量:可以在声明时初始化或在构造函数中初始化。
      • 实例变量:在类中声明,可以在声明时初始化或在构造函数中初始化。
    2. 作用范围:
      • 局部变量:只在其所在的方法、构造函数或代码块中可见。
      • 类变量:整个类中的所有方法、构造函数和代码块都可以访问类变量。
      • final 修饰的变量:与其它变量类型类似,作用范围取决于其所在的上下文。
      • 实例变量:每个类的实例(对象)都有自己的实例变量副本,只能通过对象进行访问。

总结

局部变量、类变量、被 final 关键字修饰的变量和实例变量在初始化位置和作用范围上有所不同。

  • 它们都是在类的内部进行声明,并且可以使用访问修饰符来限制对其的访问。

  • 变量类型可以是任何基本类型或引用类型。

    变量之间的 持久性和作用范围的 大小关系(final可以是局部变量、实例变量或类变量 这里不做比较)

在这里插入图片描述

按作用范围从小到大排序,可以按照以下顺序:

  1. 局部变量:局部变量的作用范围限制在声明它的方法、构造函数或代码块内部。它们只能在声明所在的范围内使用,超出范围后就无法访问。
  2. 实例变量:实例变量是定义在类中、方法之外的变量。每个类的实例都拥有自己的实例变量副本,在整个类的所有成员方法中都可以访问和修改这些变量。
  3. 类变量(静态变量):类变量属于整个类而不是特定的实例。它们在类加载时被初始化,并且在整个类的所有实例之间共享相同的值。类变量可以通过类名直接访问。

按持久性从小到大分类变量可以按照以下顺序:

  1. 局部变量:局部变量的生命周期仅限于包含它们的方法、构造函数或代码块的执行过程。当方法执行完毕或代码块结束时,局部变量将被销毁。
  2. 实例变量:实例变量属于类的实例,并且在创建对象时被初始化。它们在对象被销毁之前一直存在,即对象存在,实例变量也存在。
  3. 类变量(静态变量):类变量属于整个类而不是特定的实例。它们在类加载时被初始化,且在整个程序运行期间都存在。即使没有创建类的实例,类变量也可以被访问。

与线程安全相关知识点

  • static 变量
    当多个线程同时访问和修改类变量时,可能会出现以下线程安全问题:

    1. 竞态条件(Race Condition):如果多个线程同时对类变量进行写操作或读写操作,可能导致不可预测的结果。例如,一个线程正在修改类变量的值,而另一个线程同时在读取该变量的值,可能导致读取到不一致或过时的数据。
    2. 内存可见性问题(Visibility Problem):当一个线程修改了类变量的值后,其他线程可能无法立即感知到这个变化。这是因为每个线程都有自己的工作内存,它们可能将类变量的副本保存在各自的工作内存中。因此,其他线程可能仍然访问的是旧值。
    3. 并发更新问题(Concurrent Update Problem):当多个线程同时对类变量进行修改时,可能会导致数据不一致性。例如,多个线程同时递增一个类变量的值,最终结果可能不符合预期。
      如图所示:
      在这里插入图片描述

    要解决类变量的线程安全问题,可以采取以下措施:

    1. 使用同步机制:通过使用关键字 synchronized 或使用锁(如 ReentrantLock)来保证同一时间只有一个线程能够访问类变量,从而避免竞态条件和内存可见性问题。
    2. 使用原子操作:可以使用原子类(如 AtomicInteger)来执行对类变量的原子操作,保证线程安全。
    3. 避免共享:如果类变量不需要共享,并且每个线程都需要拥有自己的副本,可以将类变量声明为局部变量或实例变量,以避免线程安全问题。
      需要根据具体情况选择适当的线程安全措施,并在设计和编写代码时考虑到多线程环境下的并发访问问题。
  • 局部变量

在局部变量中引用了一个对象,且该对象本身存在线程安全问题,那么在访问该对象时仍然需要采取适当的同步措施,以避免线程安全问题的发生。

例如:引入形参或者有返回值的情况下就会有线程安全问题
解决方法与上面类似,需要采取适当的同步机制。


相信有一定基础的小伙伴已经发现了,final关键字修饰的变量可以是 : 成员变量 类变量 局部变量
不过作者认为final关键字修饰的变量比较特殊,就拿出来和其他变量一起介绍啦。

相关文章:

一文读懂java变量类型

前言 在学习和使用Java编程语言时&#xff0c;理解变量类型是至关重要的基础知识。Java是一种静态类型语言&#xff0c;强调变量必须先声明其类型&#xff0c;才能进行后续操作。因此&#xff0c;对于初学者来说&#xff0c;了解Java中不同的变量类型及其特性是迈向编程成功的…...

解决windows下git操作提示用户名密码错误的问题

当代码从一个平台切换到另一个平台的时候&#xff0c;需要做两步操作&#xff0c;第一步就是更新git的仓库地址&#xff0c;在项目的.git/config文件里面修改&#xff0c;这一步做完之后&#xff0c;就可以推送代码到新的仓库了&#xff0c;这里就是重点来了。 一般第一次推动代…...

ESP32开发:Clion配置IDF

IDF环境搭建 使用安装包安装IDF 可以通过安装包进行安装&#xff0c;如下图&#xff1a; 下载链接如下&#xff1a;https://dl.espressif.cn/dl/esp-idf/?idf4.4 安装好后&#xff0c;IDF会添加环境变量IDF_TOOLS_PATH&#xff0c;如果要安装多个IDF&#xff0c;为了防止冲…...

伦敦金的走势高低的规律

伦敦金市场是一个流动性很强的市场&#xff0c;其价格走势会在诸多因素的影响下&#xff0c;出现反复的上下波动&#xff0c;如果投资者能够在这些高低走势中找到一定的规律&#xff0c;在相对有利的时机入场和离场&#xff0c;就能够通过不断的交易&#xff0c;累积大量的财富…...

【C#-1】C#调用matlab生成的dll库

matlab打包dll 1、matlab示例程序&#xff1a; function untitled4(x)z peaks(x);figuresurf(z) end 2、输入deploytool打包matlab程序&#xff0c;具体如下&#xff1a; 3、拷贝 打包成功后&#xff0c;将生成for_redistribution_files_only文件夹中的dll文件拷贝到C#程序…...

MATLAB中pdist和pdist2的区别

一、pdist 和 pdist2 是MATLAB中用于计算距离矩阵的两个不同函数&#xff0c;它们的区别在于输入和输出以及一些计算选项。 pdist: pdist函数用于计算一组点之间的距离。 输入&#xff1a;通常接受一个矩阵&#xff0c;矩阵的每一行代表一个数据点&#xff0c;矩阵的列代表数据…...

直播平台源码开发搭建APP的DASH协议:流媒体技术其中一环

在直播平台源码APP中&#xff0c;有着许许多多、多种多样的功能&#xff0c;比如短视频功能&#xff0c;帮助我们去获取信息&#xff0c;看到全世界用户身边发生的事情或是他们的生活&#xff1b;又比如直播功能&#xff0c;为用户提供了实时的娱乐享受&#xff0c;还让一些用户…...

【前端】js解码base64

【前端】js解码base64 //不会乱码 function strTob(base64) {// 对base64转编码var decode atob(base64)decode escape(decode)// 编码转字符串var str decodeURIComponent(decode)return str } atob 中文乱码的解决方案 decode escape(decode) // 编码转字符串 v…...

Apipost:API开发者的协同工作神器

在当今快速发展的数字化时代&#xff0c;API已成为企业与开发者实现数据互通、应用集成的重要桥梁。然而&#xff0c;随着API数量的不断增加&#xff0c;API开发、调试、测试、文档等工作也变得越来越复杂。为了解决这一痛点&#xff0c;一款名为Apipost的API协同研发工具应运而…...

照片动起来软件有哪些?试试这几个

照片动起来软件有哪些&#xff1f;将照片动起来可以让照片更加生动有趣&#xff0c;让人们更容易吸引到你的照片。在社交媒体和短视频的时代&#xff0c;人们需要更多的方式来吸引别人的注意力。让照片动起来可以让你的照片变得更加生动、更加有趣&#xff0c;让人们更容易停留…...

【LeetCode】146.LRU缓存

题目 请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。 实现 LRUCache 类&#xff1a; LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存int get(int key) 如果关键字 key 存在于缓存中&#xff0c;则返回关键字的值&#xff0c;否则…...

2021-2023顶会190+篇ViT高分论文总结(通用ViT、高效ViT、训练transformer、卷积transformer等)

今天分享近三年&#xff08;2021-2023&#xff09;各大顶会中的视觉Transformer论文&#xff0c;有190篇&#xff0c;涵盖通用ViT、高效ViT、训练transformer、卷积transformer等细分领域。 全部论文原文及开源代码文末直接领取 General Vision Transformer&#xff08;通用V…...

堆相关例子-最大线段重合问题

问题描述 给定很多线段&#xff0c;每个线段都有两个数[start, end]&#xff0c; 表示线段开始位置和结束位置&#xff0c;左右都是闭区间 规定&#xff1a; 1&#xff09;线段的开始和结束位置一定都是整数值 2&#xff09;线段重合区域的长度必须>1 返回线段最多重合…...

Ztree的日常使用记录

1. 树节点名称中使用超文本标签 view.nameIsHTML设置为true即可 var setting {view: {nameIsHTML: true},check: {enable: true},data : {simpleData : {enable : true}} }; 2. 使用自定义的title显示 view.showTitle设置为true, 在data.key中声明title对应的字段名即可 …...

PYTHON 3.10中文版官方文档

大家好&#xff0c;我是涛哥。 很多问我涛哥学习Python看啥&#xff0c;一般我都会建议多看看官方文档&#xff0c;因为官方文档真的周到了&#xff0c;啥内容都有&#xff0c;比如新手安装&#xff0c;标准库&#xff0c; AIP参考手册&#xff0c;常见FAQ问题&#xff0c;太…...

TLS协议深度解析:挖掘现代网络安全防御的底层技术

正常简单的通讯 1、服务器生成一对密钥&#xff0c;公钥A、私钥A 2、浏览器请求服务器时&#xff0c;服务器把公钥A传给浏览器 3、浏览器随机生成一个对称加密的密码S&#xff0c;用公钥A加密后传给服务器 4、服务器接收后&#xff0c;用私钥A解密&#xff0c;得到密钥S 5、浏…...

python的time各种用法

1、time Python的time模块提供了许多用于处理时间的功能。以下是一些常用的time模块的函数及其用法&#xff0c;并附有示例&#xff1a; time()&#xff1a;返回当前时间的时间戳&#xff08;自1970年1月1日00:00:00起的秒数&#xff09;。 import timecurrent_time time.t…...

Vue中使用vue-router

Vue中使用vue-router 1. 安装vue-router2. 创建路由页面3. 创建router文件4. 挂载router5. 使用 1. 安装vue-router npm install vue-router3.6.5 --save2. 创建路由页面 HomeView.vue <template><div>home</div> </template><script>export …...

uni-app之android原生插件开发

一 插件简介 1.1 当HBuilderX中提供的能力无法满足App功能需求&#xff0c;需要通过使用Andorid/iOS原生开发实现时&#xff0c;可使用App离线SDK开发原生插件来扩展原生能力。 1.2 插件类型有两种&#xff0c;Module模式和Component模式 Module模式&#xff1a;能力扩展&…...

javaee spring aop实现事务 项目结构

spring配置文件 <?xml version"1.0" encoding"UTF-8"?> <beans xmlns"http://www.springframework.org/schema/beans"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xmlns:context"http://www.springframewo…...

9.9校招 实习 内推 面经

绿泡*泡&#xff1a; neituijunsir 交流裙 &#xff0c;内推/实习/校招汇总表格 1、自动驾驶一周资讯 -理想汽车计划进军自动驾驶卡车领域&#xff0c;宝马联合亚马逊开发下一代自动驾驶平台&#xff0c;丰田汽车重组自动驾驶和人工智能子公司 自动驾驶一周资讯 -理想汽车…...

互联网医院App开发:构建医疗服务的技术指南

互联网医院App的开发是一个复杂而具有挑战性的任务&#xff0c;但它也是一个充满潜力的领域&#xff0c;可以为患者和医疗专业人员提供更便捷的医疗服务。本文将引导您通过一些常见的技术步骤来构建一个简单的互联网医院App原型&#xff0c;以了解该过程的基本概念。 技术栈选…...

阅读分享--重读Youtube深度学习推荐系统论文,字字珠玑,惊为神文

重读Youtube深度学习推荐系统论文,字字珠玑,惊为神文 https://zhuanlan.zhihu.com/p/52169807 废话不多说,下面就跟大家分享一下两次拜读这篇论文的不同体验和收获。 第一遍读这篇论文的时候,我想所有人都是冲着算法的架构去的,在深度学习推荐系统已经成为各大公司“基本…...

使用Python操作CSV文件,方便又快捷

概念 CSV是逗号分隔值或者字符分割值&#xff0c;其文件以纯文本形式存储表格数据。 CSV文件可以用文本文件或者转换成EXCEL&#xff08;直接用EXCEL也可以&#xff0c;但是可能会有一些问题&#xff09;打开。因此更适合通过CSV文件进行程序之间转移表格数据。 应用场景 需…...

深入探索KVM虚拟化技术:全面掌握虚拟机的创建与管理

文章目录 安装KVM开启cpu虚拟化安装KVM检查环境是否正常 KVM图形化创建虚拟机上传ISO创建虚拟机加载镜像配置内存添加磁盘能否手工指定存储路径呢&#xff1f;创建成功安装完成查看虚拟机 KVM命令行创建虚拟机创建磁盘通过命令行创建虚拟机手动安装虚拟机 KVM命令行创建虚拟机-…...

javaee springMVC model的使用

项目结构图 pom依赖 <?xml version"1.0" encoding"UTF-8"?><project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org…...

Spring与Docker:如何容器化你的Spring应用

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…...

试图替代 Python 的下一代AI编程语言:Mojo

文章目录 为什么叫 Mojo &#xff1f;Python 家族的一员&#xff0c;MojoPython 的好处&#xff1a;Python 兼容性Python 的问题移动和服务器部署&#xff1a;Python 子集和其他类似 Python 的语言&#xff1a; Mojo 是一种创新的编程语言&#xff0c;结合了 Python 的可用性和…...

【数据结构】栈、队列和数组

栈、队列和数组 栈队列数组数组的顺序表示和实现顺序表中查找和修改数组元素 矩阵的压缩存储特殊矩阵稀疏矩阵 栈 初始化 #define MaxSize 50//栈中元素的最大个数 typedef char ElemType;//数据结构 typedef struct{int top;//栈顶指针ElemType data[MaxSize];//存放栈中的元…...

python算法调用方案

1、python算法部署方案 &#xff08;1&#xff09;独立部署 算法端和应用端各自独立部署。 使用WSGI&#xff08;flask&#xff09;web应用A包装算法&#xff0c;并发布该应用A。 应用端B 通过httpclient调用算法应用A中的api接口。 &#xff08;2&#xff09;统一部署 算法…...

建设银行招标网站/深圳网络推广专员

返回目录 今天写缓存篇的第一篇文章&#xff0c;在写完目录后&#xff0c;得到了一些朋友的关注&#xff0c;这给我之后的写作带来了无穷的力量&#xff0c;在这里&#xff0c;感谢那几位伙伴&#xff0c;哈哈&#xff01; 书归正传&#xff0c;今天我带来一个Static静态成员的…...

wordpress免费商城主题/潍坊自动seo

ASP.NET 支持两组性能计数器&#xff1a;系统和应用程序。前者在 ASP.NET 性能计数器对象中的 PerfMon 中公开&#xff1b;后者在 ASP.NET Applications 性能对象中公开。ASP.NET 性能对象中的 State Server Sessions 计数器&#xff08;仅适用于在其中运行状态服务器的服务器计…...

郑州网站建设首选创新/培训机构好还是学校好

配置一个数据源 Spring在第三方依赖包中包含了两个数据源的实现类包&#xff0c;其一是Apache的DBCP&#xff0c;其二是 C3P0。可以在Spring配置文件中利用这两者中任何一个配置数据源。 DBCP数据源 DBCP类包位于 /lib/jakarta-commons/commons-dbcp.jar&#xff0c;DB…...

西安做网站排名/做网页

创建表的两种办法&#xff1a; 使用DBMS 提供的交互式创建和管理数据库表的工具&#xff1b;直接用SQL 语句创建。表创建基础 创建表示例&#xff1a; 1 CREATE TABLE Products 2 ( 3 prod_id CHAR(10) NOT NULL,--是否可以为null 4 vend_id CHAR(10) NOT NULL, 5 …...

做网站的专业叫啥/关键词优化seo排名

一、约束条件约束类型关键字默认约束default 值非空约束not null唯一约束unique key自增长约束auto_increment主键约束primary key外键约束foreign key1.1 默认约束(default 默认值)初始值设置&#xff0c;插入记录时&#xff0c;如果没有明确为字段赋值&#xff0c;则自动赋予…...

如何查看网站点击量/查询网站流量的网址

1.触发器 这是一个非常简单直接的解决方案&#xff0c;我们只需要将DTS引擎驻留在比如windows服务中&#xff0c;该引擎通过数据库的触发器事件获取源表数据更新的所有情况&#xff0c;即增量&#xff0c;然后相应的更新目的表。然而&#xff0c;由谁来创建触发器了&#xf…...