- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
全部我想为这样的数据库创建头文件。它包含以下六个文件。
数据库.h
#import <Foundation/Foundation.h>
#import "sqlite3.h"
@interface Database : NSObject
{
sqlite3 *mydb;
}
-(void) openDB;
-(NSString *) filePath;
-(BOOL) createTable;
+(Database*)sharedInstance;
@end
数据库.m #导入“数据库.h”
@implementation Database
static Database* dbase = nil;
+(Database*)sharedInstance
{
if (dbase == nil)
{
dbase = [[Database alloc] init];
}
return dbase;
}
-(NSString *) filePath{
NSArray *paths =NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES);
NSString *documentsDir = [paths objectAtIndex:0];
NSLog(@"DBPATH:%@",documentsDir);
return [documentsDir stringByAppendingPathComponent:@"userdb.sqlite"];
}
-(void) openDB {
if (sqlite3_open([[self filePath]UTF8String],&mydb) != SQLITE_OK) {
sqlite3_close(mydb);
NSAssert(0,@"Database failed to Open ...");
}
BOOL result = [self createTable];
NSLog(@"Table Avi gayu 6...!!! %u",result);
}
- (BOOL) createTable
{
sqlite3_stmt *createStmt;
createStmt = nil;
NSString *tableName = @"user_table";
if ( createStmt == nil )
{
NSString *query = [NSString stringWithFormat:@"create table if not exists %@ \
(userid INTEGER PRIMARY KEY, \
name TEXT NOT NULL)",tableName];
if (sqlite3_prepare_v2(mydb, [query UTF8String], -1, &createStmt, NULL)!= SQLITE_OK )
{
return NO;
}
sqlite3_exec(mydb, [query UTF8String], NULL, NULL, NULL);
return YES;
}
return YES;
}
@end
UIDBDemoAppDelegate.h
#import <UIKit/UIKit.h>
#import "Database.h"
@class UIDBDemoViewController;
@interface UIDBDemoAppDelegate : NSObject <UIApplicationDelegate> {
UIWindow *window;
UIDBDemoViewController *viewController;
}
@property (nonatomic, retain) IBOutlet UIWindow *window;
@property (nonatomic, retain) IBOutlet UIDBDemoViewController *viewController;
@end
UIDBDemoAppDelegate.m
#import "UIDBDemoAppDelegate.h"
#import "UIDBDemoViewController.h"
@implementation UIDBDemoAppDelegate
@synthesize window;
@synthesize viewController;
#pragma mark -
#pragma mark Application lifecycle
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
[[Database sharedInstance] openDB];
[self.window addSubview:viewController.view];
[self.window makeKeyAndVisible];
return YES; }
- (void)applicationWillResignActive:(UIApplication *)application { }
- (void)applicationDidEnterBackground:(UIApplication *)application { }
- (void)applicationWillEnterForeground:(UIApplication *)application { }
- (void)applicationDidBecomeActive:(UIApplication *)application { }
- (void)applicationWillTerminate:(UIApplication *)application { }
#pragma mark -
#pragma mark Memory management
- (void)applicationDidReceiveMemoryWarning:(UIApplication *)application { }
- (void)dealloc {
[viewController release];
[window release];
[super dealloc]; }
@end
UIDBDemoViewController.h
#import <UIKit/UIKit.h>
#import "UIDBDemoAppDelegate.h"
@interface UIDBDemoViewController : UIViewController
<UITableViewDataSource> {
UIView *addView;
UILabel *uid,*unm,*cellLbl1,*cellLbl2;
UITextField *txtuid,*txtunm;
UIButton *btnadd,*btnshow;
UITableView *mytabView;
NSMutableArray *uidarray,*unmarray;
}
@property (retain, nonatomic) UIView *addView;
@property (retain, nonatomic) UILabel *uid,*unm; @property (retain, nonatomic) UITextField *txtuid,*txtunm;
@property (retain, nonatomic) UIButton *btnadd,*btnshow;
-(void) addClicked;
-(void) showClicked;
-(void) readData;
-(void) rmkeyboard;
@end
UIDBDemoViewController.m
#import "UIDBDemoViewController.h"
@implementation UIDBDemoViewController
@synthesize addView, uid,unm,txtuid,txtunm,btnadd,btnshow;
- (void)loadView
{
//Add myView
CGRect rect = CGRectMake(0, 0, 320, 480);
addView = [[UIView alloc] initWithFrame:rect];
addView.backgroundColor=[UIColor blackColor];
//Adding two Name and Password Label into myView
uid=[[UILabel alloc] initWithFrame:CGRectMake(20, 100, 100, 35)];
uid.text=@"User ID:";
uid.textAlignment=UITextAlignmentRight;
uid.textColor=[UIColor whiteColor];
uid.backgroundColor=[UIColor blackColor];
[addView addSubview:uid];
unm=[[UILabel alloc] initWithFrame:CGRectMake(20, 140, 100, 35)];
unm.text=@"User Name:";
unm.textAlignment=UITextAlignmentRight;
unm.textColor=[UIColor whiteColor];
unm.backgroundColor=[UIColor blackColor];
[addView addSubview:unm];
//Adding Two Name and Password TextField into myView
txtuid=[[UITextField alloc] initWithFrame:CGRectMake(130, 100, 150, 30)];
txtuid.placeholder=@"Enter User ID";
txtuid.borderStyle=UITextBorderStyleRoundedRect;
[txtuid addTarget:self action:@selector(rmkeyboard) forControlEvents:UIControlEventEditingDidEndOnExit];
[addView addSubview:txtuid];
txtunm=[[UITextField alloc] initWithFrame:CGRectMake(130, 140, 150, 30)];
txtunm.placeholder=@"Enter User Name";
txtunm.borderStyle=UITextBorderStyleRoundedRect;
[txtunm addTarget:self action:@selector(rmkeyboard) forControlEvents:UIControlEventEditingDidEndOnExit];
[addView addSubview:txtunm];
//Adding Two Button Login and Cancel into myView
btnadd=[UIButton buttonWithType:UIButtonTypeRoundedRect];
btnadd.frame=CGRectMake(50, 200, 100, 35);
[btnadd setTitle:@"ADD" forState:UIControlStateNormal];
[btnadd addTarget:self action:@selector(addClicked) forControlEvents:UIControlEventTouchUpInside];
[addView addSubview:btnadd];
btnshow=[UIButton buttonWithType:UIButtonTypeRoundedRect];
btnshow.frame=CGRectMake(180, 200, 100, 35);
[btnshow setTitle:@"SHOW" forState:UIControlStateNormal];
[btnshow addTarget:self action:@selector(showClicked) forControlEvents:UIControlEventTouchUpInside];
[addView addSubview:btnshow];
self.view=addView;
}
-(void) rmkeyboard
{
[txtuid resignFirstResponder];
[txtunm resignFirstResponder];
}
-(void)readData
{
NSString *query = [NSString stringWithString:@"select * from user_table"];
sqlite3_stmt *selectStatement;
uidarray = [[NSMutableArray alloc] init];
unmarray = [[NSMutableArray alloc] init];
int userid;
NSString *username;
int i=0;
if (sqlite3_prepare_v2([Database sharedInstance], [query UTF8String], -1, &selectStatement, NULL) == SQLITE_OK)
{
while (sqlite3_step(selectStatement)== SQLITE_ROW)
{
userid = sqlite3_column_int(selectStatement, 0);
username = [NSString stringWithUTF8String:(char *)sqlite3_column_text(selectStatement, 1)];
[uidarray addObject:[NSString stringWithFormat:@"%d",userid]];
[unmarray addObject:username];
NSLog(@"id=%@",[uidarray objectAtIndex:i]);
NSLog(@"unm=%@",[unmarray objectAtIndex:i]);
i++;
}
sqlite3_finalize(selectStatement);
}
}
-(void) showClicked
{
printf("Hello... showClicked");
//Tableview
mytabView = [[[UITableView alloc] initWithFrame:CGRectMake(0, 20, 320, 300) style:UITableViewStylePlain] autorelease];
[mytabView setDataSource:self];
[addView addSubview:mytabView];
[self readData];
}
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
return [uidarray count];
}
// Return a cell for the specified index path
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"any-cell"];
if (cell == nil)
{
cell = [[[UITableViewCell alloc] initWithFrame:CGRectZero reuseIdentifier:@"any-cell"] autorelease];
}
CGFloat height=[tableView rowHeight];
cellLbl1=[[UILabel alloc]initWithFrame:CGRectMake(20, 0,60, height)];
cellLbl2=[[UILabel alloc]initWithFrame:CGRectMake(150, 0,100, height)];
cellLbl1.text=[uidarray objectAtIndex:[indexPath row]];
cellLbl2.text=[unmarray objectAtIndex:[indexPath row]];
[cell addSubview:cellLbl1];
[cell addSubview:cellLbl2];
return cell;
}
-(void) addClicked
{
NSLog(@"Add Dabavyu...");
sqlite3_stmt *insertStmt;
NSString *suid = txtuid.text;
NSInteger iuid = [suid intValue];
NSString *sunm = [NSString stringWithFormat:@"%@",txtunm.text];
NSString *insertQuery = [NSString stringWithFormat:@"insert into user_table values (%d,'%@');",iuid,sunm];
NSLog(@"int Query= %@",insertQuery);
if (sqlite3_prepare_v2([Database sharedInstance], [insertQuery UTF8String], -1, &insertStmt, NULL) != SQLITE_OK)
{
NSLog(@"Inserting Failed....!!!!");
return;
}
sqlite3_exec([Database sharedInstance], [insertQuery UTF8String], NULL, NULL, NULL);
}
- (void)didReceiveMemoryWarning
{
[super didReceiveMemoryWarning];
}
- (void)viewDidUnload { }
- (void)dealloc {
[super dealloc];
}
@end
我想在 Controller 文件中使用同一个对象将数据插入数据库表user_table。我已经给出了应用程序的完整源代码。
我收到警告从不兼容的指针类型传递'sqlite3_prepare_v2'的参数1并且因此我无法从cnrtl文件打开到数据库的连接,请指导我如何解决它。
请帮助我。我是 iPhone 编程的初学者。
最佳答案
创建一个单例对象,如下所示:
在头文件中:
+(Database*)sharedInstance;
在实现文件中:
static Database* dbase = nil;
+(Database*)sharedInstance
{
if (dbase == nil)
{
dbase = [[Database alloc] init];
}
return dbase;
}
当你想调用数据库时,只需使用方法获取数据库对象[数据库共享实例]
关于iphone - 如何在委托(delegate)和 Controller 文件中使用自定义数据库 header 的相同对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9112706/
Yii::$app->runAction('new_controller/new_action', $params); 我相信这可以用来从另一个 Controller 调用 Controller Ac
这个问题类似于 this ,但我需要访问父成员(不是控制)。我不知道是否可以不使用依赖注入(inject)。 例如,我有一个父级,有一个成员调用用户,我需要从子 Controller 访问用户。 最佳
我有包含 2 个布局的根布局:- 选项面板- 绘制区域 我正在尝试的是访问 OptionsPaneController 中的 DrawAreaController 以调用其绘制方法。下面是 Optio
我的应用程序的 View Controller 层次结构设置如下: UIViewController | UITabBarController | UINavigationCo
我的应用程序的 View Controller 层次结构设置如下: UITabBarController | UINavigationController | | |
当我第一次为我目前在 Storyboard 中开发的应用程序创建基础布局时,我分两步完成: 选择我的 View Controller 并使用 Editor->Embed In->Navigation
设计要求: 显示用户可以选择的项目列表 选择一个项目后,使用后退按钮将用户带到一个新 View 。新 View 应在底部包含第一个屏幕中不存在的选项卡列表 单击选项卡中的项目时,应出现一个带有后退按钮
将父 Controller 设置为“parentCtrl as vm”,并将子 Controller 设置为“childCtrl as vmc”,以避免名称冲突,并且效果良好。 如何在子 Contro
我已经阅读了一些答案,例如关闭当前的 ViewController,但我的情况有所不同,因为我正在展示另一个 ViewController。 虽然我无法访问它的属性,但此代码显示了带有导航 Contr
如我所见,如果我们要实例化一个Model(例如,名为Post),我们只需调用: $post = new Post(); 现在,我还想实例化一个Controller(例如,名为Post,并为此 Cont
我已经疯狂地在整个网络上搜索解决我的问题的方法,但目前还没有。我的问题是我必须检查是否在 HTTP 请求中获得特定文本,该请求在一个 while 循环中,如果我这样做了,那么我应该离开循环并继续线程,
我想用this.get('controllers.pack.query');要得到App.PackQueryController在 App.PackController ,但失败了。 我认为问题是 E
我刚开始使用 Laravel。当我使用 codeigniter 或 zend 框架时,我可以将我的 Controller 组织到一个单独的目录中。例如,我可以创建“user/permission.ph
在 emberjs 前 2 我们可以从另一个 Controller 访问 Controller 或 Controller 中的任何方法 以下方式: App.get('router').get('nav
这可能是非常简单的实现,但我是 iOS 编程的新手,我似乎被卡住了。 所以,基本上,我有一个选项卡式应用程序。我决定除了标签栏之外还需要一个导航栏。为此,我放置了标签栏 Controller ,然后添
我有这个列表 Controller , define([ 'jquery', 'app' ], function ($,app) { app.controller("ListC
我有 3 个 Controller :RootController、FirstController 和 SecondController。我想从 RootController -> FirstCont
我有以下 Controller : /controllers/api/base_controller.rb /controllers/api/v1/articles_controller.rb 当为文
我是 Angular JS 的新手,尝试在另一个 Controller 中调用一个 Controller ,但出现以下错误。 ionic.bundle.js:21157 TypeError: $con
我有一个标签栏 Controller 和它的 3 个 child ,我还有另一个 View ,我制作了一个从 child 到 View Controller 的自定义转场,还有一个从 View Con
我是一名优秀的程序员,十分优秀!