Microsoft MVP성태의 닷넷 이야기
내솔루션 판매 시 1.0.0.0 폴더와 Sqlite 배포 [링크 복사], [링크+제목 복사],
조회: 10684
글쓴 사람
guest
홈페이지
첨부 파일
 

내솔루션의 exe파일을 타인이 설치 후 타인 컴퓨터 내에 Sqlite에 Write 기능이 필요한 경우

1) 타인 컴퓨터에 Write기능이 허용은 제한적이어야 하므로 타인 컴퓨터의 AppData/Local/1.0.0.0폴더만
   원칙적으로 사용할 수 있다. 이것은 Application.LocalUserAppDataPath를 의미한다.

2) 타인 컴퓨터에 프로그램설치 시 1.0.0.0 폴더가 생성되지 않는 경우도 있으므로
    Directory.CreateDirectory(destDirName)로 폴더를 생성해야 한다

위의 내용이 맞다면 만약 타인 컴퓨터에 1.0.0.0 폴더가 숨김이 적용된 상태여도
위 절차는 적용될 수 있는지요?









[최초 등록일: ]
[최종 수정일: 4/17/2023]


비밀번호

댓글 작성자
 



2023-04-17 08시29분
[guest] 질문처럼하지 않고 아래처럼 하면 자동으로 Sqlite db파일이 형성되는 지요?

public async static void InitializeDatabase()
{
     await ApplicationData.Current.LocalFolder.CreateFileAsync("sqliteSample.db", CreationCollisionOption.OpenIfExists);
     string dbpath = Path.Combine(ApplicationData.Current.LocalFolder.Path, "sqliteSample.db");
     using (SqliteConnection db =
        new SqliteConnection($"Filename={dbpath}"))
    {
        db.Open();

        String tableCommand = "CREATE TABLE IF NOT " +
            "EXISTS MyTable (Primary_Key INTEGER PRIMARY KEY, " +
            "Text_Entry NVARCHAR(2048) NULL)";

        SqliteCommand createTable = new SqliteCommand(tableCommand, db);

        createTable.ExecuteReader();
    }
}
[guest]
2023-04-17 09시45분
그냥... 직접 해보시면 것이 더 빠르지 않을까요? 원래 질문의 경우, 간단하게 폴더를 숨김 처리한 다음 그 안의 파일이 열리는지 테스트해 보시면 될 듯하고, 덧글의 질문 같은 경우에도 코드까지 만들었으니 지금 당장 해보시면 될 것 같은데요.
정성태
2023-04-18 09시58분
[guest] 여러 번 다 해봤습니다ㅜㅜ 좀 더 나은 접근법을 찾는 것이죠
고수들의 접근법이 궁금해서요

[1.0.0.0 - 이미지]
이미지가 pixabay.com처럼 수백만장이면 배포 시 1.0.0.0을 사용할 필요없지만
호스팅서비스를 비용 등의 이유로 안만드는 경우

이미지가 1만장 정도되는 경우 이 걸 user가 이용하도록 허용할 때
저렇게 하는게 스탠다드한 접근법인지요?
[guest]
2023-04-18 03시47분
[guest] [초보전용] exe파일 만들기 전에 db작업을 하는 경우
db를 repos폴더에 만들지 마시고(C:\Users\여러분\source\repos\여러분플젝이름
db는 C:\Users\여러분\AppData\Local\여러분플젝이름\여러분플젝이름\1.0.0.0\test.sqlite에
 만들면 좋을 듯 합니다 Application.LocalUserAppDataPath가 1.0.0.0주소네요

[db만들기/table생성 코드]
MessageBox.Show(Application.LocalUserAppDataPath);
string path1 = Path.Combine(Application.LocalUserAppDataPath, "synccc.sqlite");
string dbConnectionString = @"Data Source=" + path1 + ";Version=3;";

if (!System.IO.File.Exists(path1))
{
    SQLiteConnection.CreateFile(path1);

    using (SQLiteConnection sqliteConnection = new SQLiteConnection(path1))
    {
        sqliteConnection.Open();

        using (SQLiteCommand sqliteCommand = new SQLiteCommand(sqliteConnection))
        {
             sqliteCommand.CommandText = @"CREATE TABLE Cars(Id INTEGER PRIMARY KEY, Name TEXT, Price INT)";

              sqliteCommand.ExecuteNonQuery();
        }

        sqliteConnection.Close();
    }
}
[guest]
2023-04-21 08시22분
[gwise] exe파일이 설치됐다면 그 폴더에는 read/write 권한이 있다는 얘기겠죠. 그럼 그 폴더에 sqlite을 생성하면 됩니다.

생성은 크게 초기에 하는 것과 컬럼 수정으로 나눠서 보면 됩니다.
1. 생성
생성은 매번 호출 될 터이니 아래 처럼 if not exists 를 해주시고
string sql = string.Empty;
//Item
sql = @"CREATE TABLE if not exists Item(
        [ItemId] INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
        [ItemName] TEXT NOT NULL,
        [Barcode] TEXT NOT NULL DEFAULT(''),
        [Sku] TEXT NOT NULL DEFAULT(''),
        [Location] TEXT NOT NULL DEFAULT(''),
        [Category] TEXT NOT NULL DEFAULT(''),
        [UnitCost] NUMERIC NOT NULL DEFAULT(0),
        [UnitPrice] NUMERIC NOT NULL DEFAULT(0),
        [IsUsed] TEXT NOT NULL DEFAULT('Y'),
        [Comment] TEXT NOT NULL DEFAULT(''),
        [CreatedDate] TEXT NOT NULL DEFAULT(strftime('%Y-%m-%d %H:%M:%f', 'now', 'localtime')),
        [CreatedEmp] TEXT NOT NULL DEFAULT(''),
        [ModifiedDate] TEXT NOT NULL DEFAULT(strftime('%Y-%m-%d %H:%M:%f', 'now', 'localtime')),
        [ModifiedEmp] TEXT NOT NULL DEFAULT(''),
        [AddColumns] TEXT NOT NULL DEFAULT('')
    )";
new SqliteCommand(sql, conn).ExecuteNonQuery();

sql = @"CREATE Unique INDEX if not exists [Item.idx1] ON Item ([ItemName])";
new SqliteCommand(sql, conn).ExecuteNonQuery();

2. 컬럼 추가
컬럼이 추가 됐는지 확인 하고
public bool AddColumnIfExist(string table, string column)
{
    using (SqliteConnection connection = CreateConnection())
    {
        SqliteCommand selectCommand = new SqliteCommand();
        selectCommand.Connection = connection;
        selectCommand.CommandText = $"PRAGMA table_info({table});";
        SqliteDataReader reader = selectCommand.ExecuteReader();

        while (reader.Read())
        {
            if (column.Equals(reader["name"]))
            {
                Console.WriteLine("OK");
                return true;
            }
        }
    }
    return false;
}

없다면 컬럼 추가
public int AlterTableAddColumn(string table, string column, string type)
{
    int result;
    using (SqliteConnection connection = CreateConnection())
    {
        SqliteCommand selectCommand = new SqliteCommand();
        selectCommand.Connection = connection;
        selectCommand.CommandText = $"ALTER TABLE {table} ADD {column} {type};";
        result = selectCommand.ExecuteNonQuery();
    }

    return result;
}

이렇게 하면 됩니다.
[guest]

... 76  77  78  79  80  [81]  82  83  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
4659/23/200611867vb.net에서 c에서 보내는 Post메쎄지를 잡아서 처리할수 없을가요? [1]
464정윤수9/22/200613686asp.net 에서 DataSet 을 RecordSet 으로 변환 [2]
463sagi...9/22/200612721IE 제어 (BHO) 중 데이터 형에 질문 드립니다. [1]
462[손님]9/21/200614036ASP.NET 에서 COM+ 호출시 프로그램 구조를 어떻게 만들어야 할지...조언 부탁합니다. [2]파일 다운로드1
461정태운9/19/200613987Vista RC1에서 XPS Document를 Image로 변환하는 코드의 특정 API 가 동작하지 않습니다. [2]
459이방은9/14/200613015축하합니다.. [1]
458이승용9/7/200614368스마트 클라이언트 관련 질문입니다. [4]
456guest9/7/200613956데이타셋 암호화 방법...이 있을까요? [2]
451임은주8/31/200613726mms 스트림을 로컬 파일로 저장해주는 프로그램 에 대해서 여쭤볼께요 [1]
448guest8/28/200614160서버인증서및클라이언트인증서 발급
449정성태8/28/200613784    답변글 [답변]: 서버인증서및클라이언트인증서 발급
450ligh...8/29/200614023        답변글 [답변]: [답변]: 서버인증서및클라이언트인증서 발급 [3]
468light9/28/200614084            답변글 [답변]: [답변]: [답변]: 서버인증서및클라이언트인증서 발급
472정성태10/5/200614526    답변글 [답변]: 서버 인증서 및 클라이언트 인증서 발급
475ligh...10/11/200613450        답변글 [답변]: [답변]: 서버인증서및클라이언트인증서 발급
446윤경재8/20/200618836COM+ 프로젝트 디버깅 방법. [2]파일 다운로드1
442이남호8/7/200614047스마트클라이언트에 Farpoint Winform을 이용했는데 배포가 안되요.
443이남호8/7/200615907    답변글 [답변]: 스마트클라이언트에 Farpoint Winform을 이용했는데 배포가 안되요.
441강혜영8/5/200614864SHDocVw를 이용한 익스플로어 제어
444정성태8/7/200613006    답변글 [답변]: SHDocVw를 이용한 익스플로어 제어
445강혜영8/8/200613692        답변글 [답변]: [질문]: SHDocVw를 이용한 익스플로어 제어 [1]
437혀기7/25/200612393DirectoryEntry의 Childrend에 Add할때 엑세스가 거부됩니다~ㅜㅜ [2]파일 다운로드1
436조성택7/24/200612198IE를 가로채서 그리고 싶을때.. [1]
439태기7/25/200612864    답변글 [답변]: IE를 가로채서 그리고 싶을때..(재질문) [1]파일 다운로드1
435이영균7/21/200613618작그마한 스마트클라이언트 프로젝트를 진행하고 있습니다. [1]파일 다운로드1
431혁이7/19/200612233UpdatePanel(Atlas)위의 SmartClient가 이벤트후 사라집니다. ㅜㅜ파일 다운로드1
... 76  77  78  79  80  [81]  82  83  84  85  86  87  88  89  90  ...