IOS高级编程之二:IOS的数据存储与IO

一、应用程序沙盒

     IOS应用程序职能在系统为该应用所分配的文件区域下读写文件,这个文件区域就是应用程序沙盒。所有的非代码文件如:图片、声音、映象等等都存放在此。

在mac中command+shift+G命令,然后输入users/用户名/library命令进入库,然后依次进入application support/iphone simulator/版本/applications文件夹,这里面的各个文件夹对应着各个应用程序。

Documents:除了基于NSUserDefaults的首选项设置外,应用程序的数据、文件都保存在该目录下

Library:基于NSUserDefaults的首选项参数保存在Library/Preferences下

tmp:应用程序存储临时文件,ios同步时itunes不会同步这里面的数据,当应用程序不在需要这些文件时,应当删除以避免占用空间。

获取documents路径:

1 NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES);
2 NSString *dd = [paths objectAtIndex:0];

获取tmp目录:

1 NSString *tempPath = NSTemporaryDirectory();

那么我们在保存数据时使用哪种发式比较好呢,这个当然还要具体情况具体对待。
当保存小数据量的数据时,可以使用NSArray或者NSDictionary,调用writeToFile:atomically:方法写入一个文件,使用时读取文件内容即可。

当保存大数据量的数据时,可以选择使用sqllite,ios提供了CoreData框架。

 

二、应用程序参数与用户默认设置

1、使用Settings Bundle

Settings Bundle时应用程序中的一组特殊文件,用于保存较简单的各种配置信息。如果使用了Settings Bundle,ios自带的设置应用则会显示你的app

2、使用NSUserDefaults读取、保存应用程序参数

NSUserDefaults是一个单例类,每个应用程序只有一个NSUserDefaults对象,Settings Bundle设置的参数,也可以通过NSUserDefaults来读取和设置

获取NSUserDefaults的方法:

1 NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];

获取NSUserDefaults对象后,可以获取和设置应用程序参数

xxForKey:(NSString *) key  =>xx表示各种类型,根据key获取值

setBool:(xxx) value forKey:(NSString *) key =>设置参数

设置完参数后,调用synchronize方法进行保存。

3、属性列表

属性列表就是文章开始提到的利用NSArray和NSDictionary将数据写入到文件的保存方法。

但是有一些限制,只有下列类型的值保存到NSArray和NSDictionary中才可以直接调用writeToFile方法执行保存:

NSArray、NSMutableArray、NSDictionary、NSMutableDictionary、NSData、NSMutableData、NSString、NSMutableString、NSValue、NSNumber

如果NSArray和NSDictionary保存了我们自定义的类,那么将不能直接调用writeToFile方法执行保存。(可以考虑使用对象归档的方法进行保存)

 1 //使用属性列表保存3个用户的账号密码
 2     accountList = [[NSMutableArray alloc] init];
 3     [accountList addObject:[NSDictionary
 4                                 dictionaryWithObjects:[NSArray arrayWithObjects:@"loginname",@"loginpwd", nil]
 5                                 forKeys:[NSArray arrayWithObjects:@"305213781",@"123123", nil]]];
 6     [accountList addObject:[NSDictionary
 7                             dictionaryWithObjects:[NSArray arrayWithObjects:@"loginname",@"loginpwd", nil]
 8                             forKeys:[NSArray arrayWithObjects:@"475782389",@"123456", nil]]];
 9     [accountList addObject:[NSDictionary
10                             dictionaryWithObjects:[NSArray arrayWithObjects:@"loginname",@"loginpwd", nil]
11                             forKeys:[NSArray arrayWithObjects:@"330577588",@"123456789", nil]]];
12     [accountList writeToFile:[self filePath] atomically:YES];
13     
14     //使用UIActionSheet提示用户保存成功
15     UIActionSheet *sheet =[[UIActionSheet alloc] initWithTitle:@"保存成功" delegate:nil cancelButtonTitle:nil destructiveButtonTitle:@"确定" otherButtonTitles:nil, nil];
16     [sheet showInView:self.view];

 

4、使用Sqlite3数据库

1)为项目增加libsqlite3.dylib,这是一个原生的C函数库

常用函数:

int sqlite3_close(sqlite3 *):关闭sqlite3 *所代表的数据连接,并释放底层数据库连接资源。在调用该函数之前,必须先调用sqlite3_finalize()函数,调用sqlite3_blob_close()函数关闭所有的blob处理器,否则将会返回SQLITE_BUSY

int sqlite3_exec(sqlite3*,const char *sql, int (*callback)(void*, int ,char**,char**),void *,char **errmsg):用于执行没有返回值的sql语句

sqlite3_int64  sqlite3_last_insert_rowid(sqlite3*):返回sqlite3代表的数据库最后一次插入行的id

int sqlite3_changes(sqlite3*):执行某条dml语句后,返回受影响行数

void sqlite3_interrupt(sqlite3*):中断一个长时间执行的查询语句

int sqlite3_complete(const char *sql):用于判断sql语句是否执行完成

int sqlite3_open(const char * filename,sqlite3 ** ppdb):打开与filename文件的链接,并让ppdb参数引用被打开的数据库连接

const char *sqlite3_sql(sqlite3_stmt *pStmt):用于提取sqlite3_stmt(预编译SQL语句产生的结果)中包装的sql语句

等等。。。太多了不一一列举了

操作sqlite数据库的大致步骤如下:

1、调用sqlite3_open方法打开与数据库的连接

2、执行语句

3、sqlite3_close函数关闭数据库连接

 

2)使用Core Data框架

Core Data框架是一个纯粹的面向对象的框架,允许开发者以面向对象的方式持久化操作SQLite数据库。core data底层的持久化存储方式可以是Sqlite数据库,也可以是xml,也可以是内存。

Core Data的核心概念是实体,由Core Data管理的模型对象,它必须是NSManagedObject类或者它的子类的实例。

Core Data应用中的核心API有如下几个:

托管对象模型(NSManagedObjectModel):该对象负责管理整个应用的所有实体以及实体之间的关联关系。当开发者使用Xcode的图形界面设计了实体与实体间的关联关系之后,需要使用该对象来加载、管理应用的托管对象模型

持久化存储协调器(NSPersistentStoreCoordinator):负责管理底层的存储文件,例如sqlite数据库等等

托管对象上下文(NSManagedObjectContext):该对象是Core Data的核心,增删改查都需要通过它来进行

实体描述(NSEntityDescription):关于某个实体的描述信息

抓取请求(NSFetchRequest):该对象封装了查询实体的请求,包括程序需要查询哪些实体、查询条件、排序规则等

使用Core Data持久化的步骤大致如下

1、创建NSManagedObjectModel对象来加载管理应用对应的托管对象模型

2、以NSManagedObjectModel对象为基础,根据实际需要创建NSPersistentStoreCoordinator对象,该对象确定底层数据的存储形式

3、以NSManagedObjectModel对象为基础,创建NSManagedObjectContext对象

4、对于普通的增、删、改操作,需要分别先新建实体、删除实体、修改实体,然后调用NSManagedObjectContext对象的save方法,保存修改

5、如果执行查询,需要先创建NSFetchRequest对象,在调用NSManagedObjectContext对象的executeFetchRequest:error:方法,返回所有匹配条件的实体组成的NSArray

 

使用Core Data的例子来和大家一起学习。

首先,创建一个创建一个Single View Application,下面有个Use Core Data选项,打上勾,之后Xcode已经为你做好了准备工作,打开AppDelete.m就可以看到

 1 #pragma mark - Core Data stack
 2 
 3 @synthesize managedObjectContext = _managedObjectContext;
 4 @synthesize managedObjectModel = _managedObjectModel;
 5 @synthesize persistentStoreCoordinator = _persistentStoreCoordinator;
 6 
 7 - (NSURL *)applicationDocumentsDirectory {
 8     // The directory the application uses to store the Core Data store file. This code uses a directory named "esitech.Unit_3" in the application's documents directory.
 9     return [[[NSFileManager defaultManager] URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask] lastObject];
10 }
11 
12 - (NSManagedObjectModel *)managedObjectModel {
13     // The managed object model for the application. It is a fatal error for the application not to be able to find and load its model.
14     if (_managedObjectModel != nil) {
15         return _managedObjectModel;
16     }
17     //获取实体模型文件对应的nsurl
18     NSURL *modelURL = [[NSBundle mainBundle] URLForResource:@"Unit_3" withExtension:@"momd"];
19     _managedObjectModel = [[NSManagedObjectModel alloc] initWithContentsOfURL:modelURL];
20     return _managedObjectModel;
21 }
22 
23 - (NSPersistentStoreCoordinator *)persistentStoreCoordinator {
24     // The persistent store coordinator for the application. This implementation creates and return a coordinator, having added the store for the application to it.
25     if (_persistentStoreCoordinator != nil) {
26         return _persistentStoreCoordinator;
27     }
28     
29     // Create the coordinator and store
30     //以持久化模型为基础,创建持久化存储协调器对象
31     _persistentStoreCoordinator = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:[self managedObjectModel]];
32     //获取sqlite数据库文件的存储目录
33     NSURL *storeURL = [[self applicationDocumentsDirectory] URLByAppendingPathComponent:@"Unit_3.sqlite"];
34     NSError *error = nil;
35     NSString *failureReason = @"There was an error creating or loading the application's saved data.";
36     //设置存储协调器采用sqlite,如果失败打印失败信息
37     if (![_persistentStoreCoordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:storeURL options:nil error:&error]) {
38         // Report any error we got.
39         NSMutableDictionary *dict = [NSMutableDictionary dictionary];
40         dict[NSLocalizedDescriptionKey] = @"Failed to initialize the application's saved data";
41         dict[NSLocalizedFailureReasonErrorKey] = failureReason;
42         dict[NSUnderlyingErrorKey] = error;
43         error = [NSError errorWithDomain:@"YOUR_ERROR_DOMAIN" code:9999 userInfo:dict];
44         // Replace this with code to handle the error appropriately.
45         // abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
46         NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
47         abort();
48     }
49     
50     return _persistentStoreCoordinator;
51 }
52 
53 
54 - (NSManagedObjectContext *)managedObjectContext {
55     // Returns the managed object context for the application (which is already bound to the persistent store coordinator for the application.)
56     if (_managedObjectContext != nil) {
57         return _managedObjectContext;
58     }
59     
60     NSPersistentStoreCoordinator *coordinator = [self persistentStoreCoordinator];
61     if (!coordinator) {
62         return nil;
63     }
64     _managedObjectContext = [[NSManagedObjectContext alloc] init];
65     //设置上下文使用的持久化类型
66     [_managedObjectContext setPersistentStoreCoordinator:coordinator];
67     return _managedObjectContext;
68 }
69 
70 #pragma mark - Core Data Saving support
71 
72 - (void)saveContext {
73     NSManagedObjectContext *managedObjectContext = self.managedObjectContext;
74     if (managedObjectContext != nil) {
75         NSError *error = nil;
76         if ([managedObjectContext hasChanges] && ![managedObjectContext save:&error]) {
77             // Replace this implementation with code to handle the error appropriately.
78             // abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
79             NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
80             abort();
81         }
82     }
83 }

三个重要的对象NSManagedObjectModelNSPersistentStoreCoordinatorNSManagedObjectContext的实例已经为你设置好了,当我们要执行相关增删改查时,直接调用委托类的managedObjectContext属性操作即可。

在创建项目后,会发现项目中有一个**.xcdatamodeld文件,点击后就会出现实体模型设计界面

在刚刚的设计视图中添加一个类:EventEntity,添加两个属性=》happenDate(Data)、name(string)
单击Xcode主菜单的Editor=》Create NSManagedObject Subclass菜单,来创建一个子类,之后你的项目中就会创建一个类:EventEntity : NSManagedObject
先完成一些准备工作,获取appdelete对象,定义一个nameCount变量记录添加了几个对象
 1 #import "SqliteViewController.h"
 2 #import "EventEntity.h"
 3 #import <Foundation/Foundation.h>
 4 #import <CoreData/CoreData.h>
 5 #import "AppDelegate.h"
 6 
 7 @interface SqliteViewController ()
 8 @property (nonatomic,weak) AppDelegate *appDelete;
 9 @property (nonatomic) int nameCount;
10 @end
11 
12 @implementation SqliteViewController
13 
14 - (void)viewDidLoad {
15     [super viewDidLoad];
16     self.nameCount = 1;
17     // Do any additional setup after loading the view.
18     self.appDelete = (AppDelegate *)[UIApplication sharedApplication].delegate;
19 }
20 
21 - (void)didReceiveMemoryWarning {
22     [super didReceiveMemoryWarning];
23     // Dispose of any resources that can be recreated.
24 }

 

5.1 添加实体
第一步:调用NSEntityDescription的 insertNewObjectForEntityForName:(NSString *) inManagedObjectContext:(NSManagedObjectContext *)方法,第一个参数为实体名,第二个参数为上下文对象
第二部:为新实体设置属性
第三部:调用NSManagedObjectContext对象的save方法保存。
 1 //添加操作
 2 - (IBAction)btnAdd_Tap:(id)sender {
 3     //创建一个新实体
 4     EventEntity *ee = [NSEntityDescription insertNewObjectForEntityForName:@"EventEntity" inManagedObjectContext:self.appDelete.managedObjectContext];
 5     //给实体设置属性
 6     ee.happenDate = [NSDate date];
 7     ee.name = [NSString stringWithFormat:@"名字%d",self.nameCount++];
 8     
 9     //定义NSError对象接收错误信息
10     NSError *error;
11     if ([self.appDelete.managedObjectContext save:&error]) {
12         [[[UIAlertView alloc] initWithTitle:@"添加操作" message:[NSString stringWithFormat:@"添加成功,添加的实体的name是:%@",ee.name] delegate:nil cancelButtonTitle:@"好的" otherButtonTitles:nil, nil] show];
13     }else
14     {
15         NSLog(@"保存时出现错误:%@,%@",error,[error userInfo]);
16     }
17 }

 

5.2 删除实体
 1 //删除操作
 2 - (IBAction)btnRemove_Tap:(id)sender {
 3     //获取要删除的实体
 4     EventEntity *entity = [self getEntityByName:@"名字1"];
 5     //从上下文对象中删除该实体
 6     [self.appDelete.managedObjectContext deleteObject:entity];
 7     NSError *error;
 8     if (![self.appDelete.managedObjectContext save:&error]) {
 9         NSLog(@"删除时出现错误:%@,%@",error,[error userInfo]);
10     }
11 }

5.3 修改实体

 1 //更新操作
 2 - (IBAction)btnUpdate_Tap:(id)sender {
 3     //获取要删除的实体
 4     EventEntity *entity = [self getEntityByName:@"名字1"];
 5     //修改实体属性
 6     entity.happenDate = [NSDate date];
 7     NSError *error;
 8     if (![self.appDelete.managedObjectContext save:&error]) {
 9         NSLog(@"删除时出现错误:%@,%@",error,[error userInfo]);
10     }
11 }

5.4 查询

 1 //根据名字查询一个对象
 2 -(EventEntity *)getEntityByName:(NSString *) name
 3 {
 4     //创建抓取数据的请求对象
 5     NSFetchRequest *request = [[NSFetchRequest alloc] init];
 6     
 7     //设置要抓取哪种类型的实体
 8     NSEntityDescription *des = [NSEntityDescription entityForName:@"EventEntity" inManagedObjectContext:self.appDelete.managedObjectContext];
 9     
10     //设置抓取实体
11     [request setEntity:des];
12     //定义抓取条件
13     NSPredicate * qcmd = [NSPredicate predicateWithFormat:@"name = %@ ",name];
14     [request setPredicate:qcmd];
15     
16     NSError *error = nil;
17     //执行查询请求
18     NSArray *result = [[self.appDelete.managedObjectContext executeFetchRequest:request error:&error] copy];
19     if (error!=nil) {
20         NSLog(@"查询单个时出现错误:%@,%@",error,[error userInfo]);
21         return nil;
22     }
23     if (result.count==0) {
24         return nil;
25     }
26     return result[0];
27 }
28 
29 //获得所有实体
30 -(NSArray *)getAllEntities
31 {
32     //创建抓取数据的请求对象
33     NSFetchRequest *request = [[NSFetchRequest alloc] init];
34     
35     //设置要抓取哪种类型的实体
36     NSEntityDescription *des = [NSEntityDescription entityForName:@"EventEntity" inManagedObjectContext:self.appDelete.managedObjectContext];
37     
38     //设置抓取实体
39     [request setEntity:des];
40     
41     NSError *error = nil;
42     //执行查询请求
43     NSArray *result = [[self.appDelete.managedObjectContext executeFetchRequest:request error:&error] copy];
44     //如果没有数据返回nil
45     if (error!=nil && result == 0) {
46         return nil;
47     }
48     return result;
49 
50 }

 

转载于:https://www.cnblogs.com/chengzi/p/4478763.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/431838.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

安卓投屏大师_苹果,安卓手机如何免费投屏?只要悄悄按下这里,便能轻松实现...

现在很多手机都有自带投屏功能&#xff0c;这样一来我们便可以将所看的视频&#xff0c;所玩的游戏投屏到电脑或电视上了&#xff0c;当然也需要这些设备支持投屏才行。一、无线投屏1、苹果手机苹果手机的投屏功能在哪里呢&#xff1f;只要打开苹果手机从下往上滑动&#xff0c…

b站电脑客户端_如何将B站的flv格式的视频转换成mp4格式

经常看到B站有精彩的视频片段&#xff0c;于是想把这些视频下载保存到电脑&#xff0c;但是发现没有下载按钮&#xff0c;是不是很悲催。有些时候想从优酷、土豆网这些视频网站下载视频&#xff0c;结果却提示要先下载视频客户端才能继续下载视频&#xff0c;运气差的话&#x…

asp.net 设置 excel alignment_教你如何用Python轻轻松松操作Excel、Word、CSV,一文就够了,赶紧码住!!!...

作者&#xff1a;奈何缘浅wyjhttps://juejin.im/post/6868073137263607821Python 操作 Excel常用工具数据处理是 Python 的一大应用场景&#xff0c;而 Excel 又是当前最流行的数据处理软件。因此用 Python 进行数据处理时&#xff0c;很容易会和 Excel 打起交道。得益于前人的…

java 页面输出一个页面_java学习之:一个完整页面输出信息的过程(以输出Doctor表中信息为例)...

最近在练习java程序&#xff0c;总结一下从数据库查询信息并输出到jsp页面的过程。主要数据处理在src.cn.javatest包下面项目预览1&#xff0c;配置项目根目录src目录下的druid.properties数据库信息(相当于一个数据库配置文件)里面的信息可以在下载druid中获得&#xff0c;只需…

[xsd学习]xsd介绍

一直以来项目中对xml格式的判断使用的都是dtd格式&#xff0c;直到最近才发现&#xff0c;不知何时都已经转为xsd来进行判断和校验&#xff0c;于是今天专门找资料看下&#xff0c;不得不说&#xff0c;对于这类资料的入门&#xff0c;w3cschool真是个不错的资料库&#xff0c;…

教学目标四个维度_【深度好文】体育教案中的教学目标与学习目标应如何表述...

体育教师大本营教学/训练/职业/成长强 烈 建 议 大 家 星 标 我 们教 学 路 上 ☆ 不 离 不 弃在以往看到的体育课的教案上&#xff0c;目标部分不是用教学目标就是用学习目标来表述&#xff0c;然而&#xff0c;这两种目标表达形式有没有本质区别&#xff1f;分别该如何表述…

java中检查性异常类_Java异常处理、java语言推崇使用检查类型异常

异常处理是java语言的重要特性之一&#xff0c;《Three Rules for effective Exception Handling》一文中是这么解释的&#xff1a;它主要帮助我们在debug的过程中解决下面的三个问题。什么出错了哪里出错了为什么出错java语言可以说是提供了过于完善的异常处理机制&#xff0c…

nodejs readfilesync 路径_Linux 磁盘多路径聚合multipath

在日常工作中我们经常遇到配置存储的多路径聚合。多路径的目的是&#xff0c;当主机HBA卡、线缆、交换机或者存储设备的控制器故障等原因造成一条物理路径失效时,服务器可以将通过此物理路径的I/O转移到其他正常的物理路径上面,应用程序不会觉察到这种改变&#xff0c;从而提高…

u 20ubuntu 安装 postfix_极力推荐和田咨询问题U型钢托盘厂家

12极力推荐和田咨询问题U型钢托盘厂家泊头市毅伽属制品有限公司坐落于河北省泊头市龙华街北4公里&#xff0c;濒临京沪、石黄高速公路以及104、307国道&#xff0c;另有廊泊路贯穿南北交通十分便利。本公司设计生产各种冷弯型钢&#xff0c;产品包括C型钢、Z型钢、U型钢、M型钢…

HTML5中lineCap端点样式遇到closePath()

定义和用法 lineCap 属性设置或返回线条末端线帽的样式。 注释&#xff1a;"round" 和 "square" 会使线条略微变长。 默认值&#xff1a;buttJavaScript 语法&#xff1a;context.lineCap"butt|round|square";属性值 值描述butt默认。向线条的每…

php鼠标悬停显示图片,鼠标滑过出现预览的大图提示效果

当鼠标滑过图片时&#xff0c;图片会出现预览的大图&#xff0c;大图下面还会有介绍文字。.aa{width:88px;height :100px;}$(function () {var x 10;var y 20;$("a.tooltip").mouseover(function (e) {this.myTitle this.title;this.title "";var imgT…

405 not allowed什么意思_二驴质问散打:为什么不救天道!面临一个亿赔款?次惑小仙女宣布与可乐分手!...

次惑小仙女发作品表示&#xff1a;对不起让你们失望了&#xff0c;慢慢也学着长大了,懂得了很多,以前每天就知道天真傻笑的玩,后来懂得了努力和加油,但是很多东西并不是大家看到的那样背后的事情谁又能知道。都认为他对我很好&#xff0c;只有自己知道&#xff0c;呵呵。有些时…

hdu.1254.推箱子(bfs + 优先队列)

推箱子 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 6021 Accepted Submission(s): 1718 Problem Description推箱子是一个很经典的游戏.今天我们来玩一个简单版本.在一个M*N的房间里有一个箱子和一个搬运…

ae合成设置快捷键_怎么在ae中剪切视频?怎么在ae里裁剪视频?

ae剪切裁剪视频教程&#xff1a;零基础学AE软件影视后期必修课程-AE新建合成-羽兔网​www.yutu.cn1、启动After Effects并导入视频第一个任务是打开一个新项目&#xff0c;并将视频加载到其中。首先从主菜单中选择新的构图。然后打开构图菜单&#xff0c;选择所需的分辨率等&am…

php js获取元素id,javascript通过中文id和class获取元素的方法

以前以为html元素中的id和class等只能通过字母数字或者下划线等特殊字符命名&#xff0c;如果单存使用中文浏览器不会报错&#xff0c;但是js是获取不到的&#xff0c;但是今天逛论坛的时候发现不是这样的。代码如下&#xff1a;运行结果&#xff1a;论坛来源是这个&#xff1a…

delphi random 六位_《蒙面唱将猜猜猜》第五季将播,六位唱将率先登场

原标题&#xff1a;《蒙面唱将猜猜猜》第五季将播&#xff0c;六位唱将率先登场新京报讯(记者 刘玮)《蒙面唱将猜猜猜》第五季将于11月1日21&#xff1a;10在江苏卫视首播&#xff0c;优酷视频全网独播。第五季中&#xff0c;猜评团不仅“觊觎”各路唱将的真实身份&#xff0c;…

java中sql之count,SQL COUNT() 函数--编程学习网

COUNT() 函数返回匹配指定条件的行数。SQL COUNT(column_name) 语法COUNT(column_name) 函数返回指定列的值的数目(NULL 不计入)&#xff1a;SELECT COUNT(column_name) FROM table_name;SQL COUNT(*) 语法COUNT(*) 函数返回表中的记录数&#xff1a;SELECT COUNT(*) FROM tabl…

苹果笔记本双系统怎么切换_2020年你该怎么选择苹果笔记本,资深用户带你讲透MacBook Air MacBook Pro...

作为一名曾经的苹果生态开发者我2012年10月份购入自己的第一台苹果笔记本&#xff1a;MacBook Pro 13寸&#xff0c;那时候还很厚重&#xff0c;机械硬盘的配置&#xff0c;为了省钱&#xff0c;在官网翻新机渠道购买的&#xff0c;记得当初新机的原价是8000多&#xff0c;翻新…

苹果6s怎么导出照片_怎么恢复苹果手机删除的照片?今天教你三种找回方法

怎么恢复苹果手机删除的照片&#xff1f;手机的出现虽然带给我们很大便利&#xff0c;同时却也带来了一些小的麻烦。在手机上很多操作步骤都很简单&#xff0c;因此&#xff0c;难免会遇到手滑误操作的情况。拿照片这项内容来说&#xff0c;我们可能误删除一些本来不需要删除的…

iptables 开放远程_远程FX正式上市 指导价11.99万-12.99万元_搜狐汽车

本文车型速览除了文章作者的主观观点外&#xff0c;我们正尝试基于全网可查的客观数据&#xff0c;为您提供中立、客观的参考依据&#xff1a;本文部分车型速览&#xff1a;畅销车型质量排行top10展开微信扫码&#xff0c;直接一次看完附近所有城市低价(附近城市均有经销商可售…