Microsoft MVP성태의 닷넷 이야기
내솔루션 판매 시 1.0.0.0 폴더와 Sqlite 배포 [링크 복사], [링크+제목 복사],
조회: 3687
글쓴 사람
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]

... 16  17  18  19  20  21  22  23  24  25  26  27  28  [29]  30  ...
NoWriterDateCnt.TitleFile(s)
5155세퉁5/7/201910673관리자 권한으로 실행 시 알림창(?) 없이 바로 실행 시킬 수 있는 방법이 있을까요?? [2]파일 다운로드1
5154Soul...5/4/20197536NamedPipe 질문드립니다. [2]
5153개태5/4/20198502WCF RESTful Service에서 enum을 parameter로 쓰는방법 [2]
5152세퉁5/3/20199513인터넷 시간을 불러와 pc에 적용 시키고 싶습니다. [3]파일 다운로드1
5151이대희5/3/20197735C# 7.3으로 개정판 출간 계획이 있으신가요? [1]
5150김이현5/2/20199117C# 딕셔너리 생성에 대해 질문드립니다. [1]
5149민성5/1/20197397ftp 이미지 업로드중 [1]
5148wpf질문4/30/20197713특정 사이트를 wpf에서 popup을 항상 허용하게 할려면 어떻게 해야할까요? [5]
5147민성4/30/20196724wpf에서 작업관리자를 띠울려면 어떻게 해야 하나요? [1]
5146불파겐4/25/20196812하나의 필드를 여러 스레드에서 읽어갈 때 스레드 동기화를 하지 않으면 문제가 생길까요? [2]
5145e구름4/17/20199753Properties.Setting.Default값에 대해 질문드립니다. [2]
5144성태님 ...4/17/20196990질문하시기 전에 10000 페이지 오류 납니다. [1]
5143헌이4/16/20197904윈도우 작업표시줄에 프로그램 띄우기 [2]파일 다운로드1
5142cab2...4/9/201913447C#으로 만든 DLL 배포하기 [10]
5141하늘사랑4/5/20198393Axinterop 래퍼에 관해서 질문드립니다. [7]
5140게스트4/1/20198000안녕하세요. 초보 개발자입니다. SD리더기에서 SD카드를 꽂으면 발생하는 이벤트 문의 [2]
5139김이현3/28/201911221C#에서 CRON 같은 스케줄러를 사용하려면 어떻게 해야 하나요? [3]
5138김지원3/22/20198840유니티 쉐이더에서 오로지 포워드 애드 패스로만 만들 수 있을까요? [1]
5137세퉁3/22/201910716wpf 쓰레드에 대해 질문 있습니다. [4]
5136KGY3/13/20197424안녕하세요 닷넷코어 콘솔 프로그램 관련 질문입니다. [1]
5135러쎌3/13/20197866ASP.NET 공부 관련해서 문의를 드립니다. [1]
5134이정호3/12/20197253SampleProfiler 예제를 이용한 Class 객체의 접근 문의 [1]파일 다운로드1
5133ㅇㅇ3/12/20198150멀티코어사용 방법에 궁금한것이 있습니다. [3]
5132존기미3/3/20198417Physical Disk Access문의 [1]
5131강용규2/25/20197530c# 개발자입니다. 타이머 질문드립니다. [1]
5130노인코래방2/25/201911123C#에서 가장 좋은 성능을 보이는 파일 읽고 쓰는 방법이 무엇인가요? [2]
... 16  17  18  19  20  21  22  23  24  25  26  27  28  [29]  30  ...